这个网站 可以列出某门编程语言的常用语法,也可以对比两种语言的基本语法差别。
在此对比Go和Rust
1. Print Hello World
打印Hello World
package main import "fmt" func main() { fmt.Println("Hello World") }
fn main() { println!("Hello World"); }
Rust 输出文字的方式主要有两种:println!() 和 print!()。这两个"函数"都是向命令行输出字符串的方法,区别仅在于前者会在输出的最后附加输出一个换行符。当用这两个"函数"输出信息的时候,第一个参数是格式字符串,后面是一串可变参数,对应着格式字符串中的"占位符",这一点与 C 语言/ Go语言 中的 printf 函数很相似。但是,Rust 中格式字符串中的占位符不是"% + 字母"的形式,而是一对 {}。
2. Print Hello 10 times
打印10次Hello World
package main import ( "fmt" ) func main() { for i := 0; i < 10; i++ { fmt.Println("Hello") } }
or
package main import ( "fmt" "strings" ) func main() { fmt.Print(strings.Repeat("Hello\n", 10)) }
fn main() { for _ in 0..10 { println!("Hello"); } }
or
fn main() { print!("{}", "Hello\n".repeat(10)); }
3. Create a procedure
Like a function which doesn't return any value, thus has only side effects (e.g. Print to standard output)
创建一个方法,没有返回值,打印一些内容
package main import "fmt" func finish(name string) { fmt.Println("My job here is done. Good bye " + name) } func main() { finish("Tony") }
fn main(){ finish("Buddy") } fn finish(name : &str) { println!("My job here is done. Goodbye {}", name); }
4. Create a function which returns the square of an integer
创建一个函数,返回一个整数的平方
func square(x int) int { return x*x }
fn square(x: u32) -> u32 { x * x } fn main() { let sq = square(9); println!("{}", sq); }
5. Create a 2D Point data structure
Declare a container type for two floating-point numbers x and y
声明一个容器类型,有x、y两个浮点数
package main import "fmt" type Point struct { x, y float64 } func main() { p1 := Point{} p2 := Point{2.1, 2.2} p3 := Point{ y: 3.1, x: 3.2, } p4 := &Point{ x: 4.1, y: 4.2, } fmt.Println(p1) fmt.Println(p2) fmt.Println(p3) fmt.Println(p4) }
输出
{0 0} {2.1 2.2} {3.2 3.1} &{4.1 4.2}
use std::fmt; struct Point { x: f64, y: f64, } impl fmt::Display for Point { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!(f, "({}, {})", self.x, self.y) } } fn main() { let p = Point { x: 2.0, y: -3.5 }; println!("{}", p); }
or
use std::fmt; struct Point(f64, f64); impl fmt::Display for Point { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { write!(f, "({}, {})", self.0, self.1) } } fn main() { let p = Point(2.0, -3.5); println!("{}", p); }
6. Iterate over list values
Do something with each item x of an array-like collection items, regardless indexes.
遍历列表的值
for _, x := range items { doSomething(x) }
package main import ( "fmt" ) func main() { items := []int{11, 22, 33} for _, x := range items { doSomething(x) } } func doSomething(i int) { fmt.Println(i) }
输出
11 22 33
fn main() { let items = vec![11, 22, 33]; for x in items { do_something(x); } } fn do_something(n: i64) { println!("Number {}", n) }
or
fn main() { let items = vec![11, 22, 33]; items.into_iter().for_each(|x| do_something(x)); } fn do_something(n: i64) { println!("Number {}", n) }
7. Iterate over list indexes and values
遍历列表的索引和值
package main import "fmt" func main() { items := []string{ "oranges", "apples", "bananas", } for i, x := range items { fmt.Printf("Item %d = %v \n", i, x) } }
输出
Item 0 = oranges Item 1 = apples Item 2 = bananas
fn main() { let items = ["a", "b", "c"]; for (i, x) in items.iter().enumerate() { println!("Item {} = {}", i, x); } }
or
fn main() { let items = ["a", "b", "c"]; items.iter().enumerate().for_each(|(i, x)| { println!("Item {} = {}", i, x); }); }
8. Initialize a new map (associative array)
Create a new map object x, and provide some (key, value) pairs as initial content.
创建一个新的map,提供一些键值对 作为初始内容
package main import "fmt" func main() { x := map[string]int{"one": 1, "two": 2} fmt.Println(x) }
输出
map[one:1 two:2]
use std::collections::BTreeMap; fn main() { let mut x = BTreeMap::new(); x.insert("one", 1); x.insert("two", 2); println!("{:?}", x); }
输出为:
("one", 1) ("two", 2)
or
use std::collections::HashMap; fn main() { let x: HashMap<&str, i32> = [ ("one", 1), ("two", 2), ].iter().cloned().collect(); println!("{:?}", x); }
输出为:
("two", 2) ("one", 1)
分 BTreeMap 和 HashMap,且都需要use进来; 前者无序,后者有序
9. Create a Binary Tree data structure
The structure must be recursive because left child and right child are binary trees too. A node has access to children nodes, but not to its parent.
创建一个二叉树
type BinTree struct { Value valueType Left *BinTree Right *BinTree }
package main import "fmt" type BinTree struct { Value int Left *BinTree Right *BinTree } func inorder(root *BinTree) { if root == nil { return } inorder(root.Left) fmt.Printf("%d ", root.Value) inorder(root.Right) } func main() { root := &BinTree{1, nil, nil} root.Left = &BinTree{2, nil, nil} root.Right = &BinTree{3, nil, nil} root.Left.Left = &BinTree{4, nil, nil} root.Left.Right = &BinTree{5, nil, nil} root.Right.Right = &BinTree{6, nil, nil} root.Left.Left.Left = &BinTree{7, nil, nil} inorder(root) }
输出
7 4 2 5 1 3 6
struct BinTree<T> { value: T, left: Option<Box<BinTree<T>>>, right: Option<Box<BinTree<T>>>, }
10. Shuffle a list
Generate a random permutation of the elements of list x
随机排序一个list
package main import ( "fmt" "math/rand" ) func main() { x := []string{"a", "b", "c", "d", "e", "f", "g", "h"} for i := range x { j := rand.Intn(i + 1) x[i], x[j] = x[j], x[i] } fmt.Println(x) }
输出
[f e c g h a d b]
or
package main import ( "fmt" "math/rand" ) func main() { x := []string{"a", "b", "c", "d", "e", "f", "g", "h"} y := make([]string, len(x)) perm := rand.Perm(len(x)) for i, v := range perm { y[v] = x[i] } fmt.Println(y) }
输出
[f h c g b a d e]
rand.Perm(x)挺有意思的一个函数,perm应该是permutation的缩写,即置换,排列。
会输出一个从0-(x-1)随机顺序排列的数组,类似洗牌,总数不变,打乱顺序
or
package main import ( "fmt" "math/rand" ) func main() { x := []string{"a", "b", "c", "d", "e", "f", "g", "h"} rand.Shuffle(len(x), func(i, j int) { x[i], x[j] = x[j], x[i] }) fmt.Println(x) }
输出
[f a h b c d g e]
or
package main import ( "fmt" "math/rand" ) func main() { x := []string{"a", "b", "c", "d", "e", "f", "g", "h"} for i := len(x) - 1; i > 0; i-- { j := rand.Intn(i + 1) x[i], x[j] = x[j], x[i] } fmt.Println(x) }
输出
[g d a h e f c b]
extern crate rand; use rand::{Rng, StdRng}; let mut rng = StdRng::new().unwrap(); rng.shuffle(&mut x);
or
use rand::seq::SliceRandom; use rand::thread_rng; fn main() { let mut x = [1, 2, 3, 4, 5]; println!("Unshuffled: {:?}", x); let mut rng = thread_rng(); x.shuffle(&mut rng); println!("Shuffled: {:?}", x); }