大家好,我是渔夫。
今天跟大家分享,当使用 Rust 一段时间后回来写 Go 的有哪些变化。自己本身大部分工作上都是主要写 Go 的,因为项目原因,以及我自己本身对 Rust 的热爱,业余时间也喜欢写各种小工具等等,所以,也越来越习惯 Rust 的写法。
以为我摆脱了 if err != nil { },在 Rust 中,很有可能会写出类似 let result = some_function(),然后使用 match 或 ? 操作符来处理 Result。习惯使用 Rust 的写法使用 ?, 模式匹配来处理错误情况,用起来还是有点舒服滴。
let result = some_function()?;
而 Go 呢,使用多返回值来处理错误,通常是返回一个结果和一个错误。
result, err := someFunction()if err != nil { // handle error}
Rust 错误处理还是吸引很多开发者的,很多其他语言开发者,抱怨要是错误处理像 Rust 那种多爽,Rust 的错误处理机制也吸收了其他编程语言中错误处理的优点,并结合了 Rust 独特的语言特性,如强类型系统、模式匹配和所有权模型,形成了一套高效、安全且易于使用的错误处理机制。
可以简单了解 Rust 错误处理与其他语言的不同:
有时候不自觉地将 Rust 的编程习惯和风格带入 Go 的编程中,使用 let 关键字代替 := , 在 Rust 中,变量通常是使用 let 关键字来声明的。如:let x = 5。而在 Go 中,变量声明和初始化通常使用 := 符号,也很容易把错误地在 Go 中使用如 let x := 5,而正确的方式是 x := 5。
Rust 程序员在编写 Go 代码时,也很容易在循环结构中不自觉地将 Go 的 := range 语法写成 Rust 风格的 in。
Rust :
let numbers = vec![1, 2, 3, 4, 5];for num in numbers { println!("{}", num);}
Go :
numbers := []int{1, 2, 3, 4, 5}for index, value := range numbers { fmt.Println(index, value)}
习惯了 Rust 后,切到写 Go 代码时,可能会错误地使用 fn 来定义函数,也会习惯性的写错。
Rust 的写法:
fn add(a: i32, b: i32) -> i32 { a + b}
Go 的写法:
func add(a int, b int) int { return a + b}
在 Rust 中,函数定义时,返回类型是通过 -> 符号指定的,紧跟在参数列表后面。
习惯性在函数中漏写 return 语句,在 Rust 中,函数的最后一个表达式会自动作为函数的返回值,除非它以分号结尾。因此,在 Rust 中编写函数时,经常省略 return 关键字。
Rust 如下例子:
fn add(a: i32, b: i32) -> i32 { a + b // 这个自动返回 a + b 的结果}
Go 例子:
必须显式使用 return
func add(a int, b int) int { return a + b}
在 Rust 开发中,标准的变量和函数命名约定是使用下划线分隔的小写字母的,即所谓的 snake_case。
Rust:
fn demo_function() { let local_variable = 100;}
Go:
func DemoFunction() { localVariable := 100}
注意,Go 的首字母大小写是有不同含义的。
好了,以上主要是分享当写 Rust 后,切到其他语言时,通常习惯性使用 Rust 的写法风格。当然有些没有想到的,以上的习惯性,那种是你习惯性指数比较高的呢。学习 Rust 建议初学者要适应编译告警一堆,还有跟编辑器做斗争。
本文链接:http://www.28at.com/showinfo-26-64498-0.html使用 Rust 后,我写 Go 的方法都变了!
声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com
上一篇: Galaxy AI 赋能影像创作 三星 Galaxy S24 系列解锁进阶体验
下一篇: 2024 年 Vue.js 会发生什么?