Rust vs Go:常用语法对比(三)

news2025/1/16 8:16:53

alt

题图来自When to use Rust and when to use Go[1]


41. Reverse a string

反转字符串

package main

import "fmt"

func Reverse(s string) string {
 runes := []rune(s)
 for i, j := 0len(runes)-1; i < j; i, j = i+1, j-1 {
  runes[i], runes[j] = runes[j], runes[i]
 }
 return string(runes)
}

func main() {
 input := "The quick brown 狐 jumped over the lazy 犬"
 fmt.Println(Reverse(input))
 // Original string unaltered
 fmt.Println(input)
}

输出

犬 yzal eht revo depmuj 狐 nworb kciuq ehT
The quick brown 狐 jumped over the lazy 犬

let t = s.chars().rev().collect::<String>();

or

fn main() {
    let s = "lorém ipsüm dolör sit amor ❤ ";
    let t: String = s.chars().rev().collect();
    println!("{}", t);
}

输出

❤ roma tis rölod müspi mérol


42. Continue outer loop

Print each item v of list a which in not contained in list b. For this, write an outer loop to iterate on a and an inner loop to iterate on b.

打印列表a中不包含在列表b中的每个项目v。 为此,编写一个外部循环来迭代a,编写一个内部循环来迭代b。

package main

import "fmt"

func printSubtraction(a []int, b []int) {
mainloop:
 for _, v := range a {
  for _, w := range b {
   if v == w {
    continue mainloop
   }
  }
  fmt.Println(v)
 }
}

func main() {
 a := []int{1234}
 b := []int{2468}
 printSubtraction(a, b)
}

mainloop is a label used to refer to the outer loop.

输出

1
3

fn main() {
    let a = ['a''b''c''d''e'];
    let b = [     'b',      'd'     ];
    
    'outerfor va in &a {
        for vb in &b {
            if va == vb {
                continue 'outer;
            }
        }
        println!("{}", va);
    }
}

'outer is a label used to refer to the outer loop. Labels in Rust start with a '.

输出

a
c
e

43. Break outer loop

Look for a negative value v in 2D integer matrix m. Print it and stop searching.

在2D整数矩阵m中寻找一个负值v,打印出来,停止搜索。

package main

import "fmt"
import "os"

var m = [][]int{
 {123},
 {11030},
 {5-2055},
 {00-60},
}

func main() {
mainloop:
 for i, line := range m {
  fmt.Fprintln(os.Stderr, "Searching in line", i)
  for _, v := range line {
   if v < 0 {
    fmt.Println("Found ", v)
    break mainloop
   }
  }
 }

 fmt.Println("Done.")
}

mainloop is a label used to refer to the outer loop.

输出

Searching in line 0
Searching in line 1
Searching in line 2
Found  -20
Done.

fn main() {
    let m = vec![
        vec![123],
        vec![11030],
        vec![5, -2055],
        vec![00, -60],
    ];
    
    'outerfor v in m {
        'innerfor i in v {
            if i < 0 {
                println!("Found {}", i);
                break 'outer;
            }
        }
    }
}

Loop label syntax is similar to lifetimes.

输出

Found -20


44. Insert element in list

Insert element x at position i in list s. Further elements must be shifted to the right.

在列表s的位置I插入元素x。其他元素必须向右移动。

package main

import "fmt"

func main() {

 s := make([]int2)
 
 s[0] = 0
 s[1] = 2
 
 fmt.Println(s) 
 // insert one at index one
 s = append(s, 0)
 copy(s[2:], s[1:])
 s[1] = 1
 
 fmt.Println(s)
}

输出

[0 2]
[0 1 2]

fn main() {
    let mut vec = vec![123];
    vec.insert(14);
    assert_eq!(vec, [1423]);
    vec.insert(45);
    assert_eq!(vec, [14235]);
    
}

45. Pause execution for 5 seconds

在继续下一个指令之前,在当前线程中休眠5秒钟。

package main

import (
 "fmt"
 "time"
)

func main() {
 time.Sleep(5 * time.Second)
 fmt.Println("Done.")
}


use std::{thread, time};
thread::sleep(time::Duration::from_secs(5));

46. Extract beginning of string (prefix)

Create string t consisting of the 5 first characters of string s. Make sure that multibyte characters are properly handled.

创建由字符串s的前5个字符组成的字符串t。 确保正确处理多字节字符。

package main

import "fmt"

func main() {
 s := "Привет"
 t := string([]rune(s)[:5])
 
 fmt.Println(t)
}

输出

Приве

fn main() {
    let s = "été 😁 torride";
    
    let t = s.char_indices().nth(5).map_or(s, |(i, _)| &s[..i]);

    println!("{}", t);
}

输出

été 😁


47. Extract string suffix

Create string t consisting in the 5 last characters of string s. Make sure that multibyte characters are properly handled.

创建由字符串s的最后5个字符组成的字符串t。 确保正确处理多字节字符

package main

import "fmt"

func main() {
 s := "hello, world! 문자"
 t := string([]rune(s)[len([]rune(s))-5:])
 fmt.Println(t)
}

输出

d! 문자


fn main() {
    let s = "tükörfúrógép";
    let last5ch = s.chars().count() - 5;
    let s2: String = s.chars().skip(last5ch).collect();
    println!("{}", s2);
}

输出

rógép


48. Multi-line string literal

Assign to variable s a string literal consisting in several lines of text, including newlines.

给变量s赋值一个由几行文本组成的字符串,包括换行符。

package main

import (
 "fmt"
)

func main() {
 s := `Huey
Dewey
Louie`


 fmt.Println(s)
}

输出

Huey
Dewey
Louie

fn main() {
    let s = "line 1
line 2
line 3"
;
    
    print!("{}", &s);
}

输出

line 1
line 2
line 3

or

fn main() {
    let s = r#"Huey
Dewey
Louie"#
;
    
    print!("{}", &s);
}

输出

Huey
Dewey
Louie

49. Split a space-separated string

拆分用空格分隔的字符串

Build list chunks consisting in substrings of input string s, separated by one or more space characters.

构建由输入字符串的子字符串组成的列表块,由一个或多个空格字符分隔。

package main

import (
 "fmt"
 "strings"
)

func main() {
 s := "Un dos tres"
 chunks := strings.Split(s, " ")
 fmt.Println(len(chunks))
 fmt.Println(chunks)

 s = " Un dos tres "
 chunks = strings.Split(s, " ")
 fmt.Println(len(chunks))
 fmt.Println(chunks)

 s = "Un  dos"
 chunks = strings.Split(s, " ")
 fmt.Println(len(chunks))
 fmt.Println(chunks)
}

输出

3
[Un dos tres]
5
[ Un dos tres ]
3
[Un  dos]

or

package main

import (
 "fmt"
 "strings"
)

func main() {
 s := "hello world"
 chunks := strings.Fields(s)

 fmt.Println(chunks)
}

输出为

[hello world]

and

package main

import (
 "fmt"
 "strings"
)

func main() {
 s := "Un dos tres"
 chunks := strings.Fields(s)
 fmt.Println(len(chunks))
 fmt.Println(chunks)

 s = " Un dos tres "
 chunks = strings.Fields(s)
 fmt.Println(len(chunks))
 fmt.Println(chunks)

 s = "Un  dos"
 chunks = strings.Fields(s)
 fmt.Println(len(chunks))
 fmt.Println(chunks)
}

输出

3
[Un dos tres]
3
[Un dos tres]
2
[Un dos]

strings.Fields 就只能干这个事儿


fn main() {
    let s = "What a  mess";

    let chunks: Vec<_> = s.split_whitespace().collect();

    println!("{:?}", chunks);
}

输出

["What""a""mess"]

or

fn main() {
    let s = "What a  mess";

    let chunks: Vec<_> = s.split_ascii_whitespace().collect();

    println!("{:?}", chunks);
}

输出

["What""a""mess"]

or

fn main() {
    let s = "What a  mess";

    let chunks: Vec<_> = s.split(' ').collect();

    println!("{:?}", chunks);
}

输出

["What""a""""mess"]

50. Make an infinite loop

写一个无限循环

for {
 // Do something
}
package main

import "fmt"

func main() {
 k := 0
 for {
  fmt.Println("Hello, playground")
  k++
  if k == 5 {
   break
  }
 }
}

输出

Hello, playground
Hello, playground
Hello, playground
Hello, playground
Hello, playground

loop {
 // Do something
}

51. Check if map contains key

Determine whether map m contains an entry for key k

检查map是否有某个key

package main

import (
 "fmt"
)

func main() {
 m := map[string]int{
  "uno":  1,
  "dos":  2,
  "tres"3,
 }

 k := "cinco"
 _, ok := m[k]
 fmt.Printf("m contains key %q: %v\n", k, ok)

 k = "tres"
 _, ok = m[k]
 fmt.Printf("m contains key %q: %v\n", k, ok)
}

输出

m contains key "cinco"false
m contains key "tres"true

use std::collections::HashMap;

fn main() {
    let mut m = HashMap::new();
    m.insert(1"a");
    m.insert(2"b");

    let k = 2;

    let hit = m.contains_key(&k);

    println!("{:?}", hit);
}

52. Check if map contains value

检查map中是否有某个值

package main

import (
 "fmt"
)

func containsValue(m map[K]T, v T) bool {
 for _, x := range m {
  if x == v {
   return true
  }
 }
 return false
}

// Arbitrary types for K, T.
type K string
type T int

func main() {
 m := map[K]T{
  "uno":  1,
  "dos":  2,
  "tres"3,
 }

 var v T = 5
 ok := containsValue(m, v)
 fmt.Printf("m contains value %d: %v\n", v, ok)

 v = 3
 ok = containsValue(m, v)
 fmt.Printf("m contains value %d: %v\n", v, ok)
}

输出

m contains value 5false
m contains value 3true

use std::collections::BTreeMap;

fn main() {
    let mut m = BTreeMap::new();
    m.insert(11"one");
    m.insert(22"twenty-two");

    {
        let v = "eight";
        let does_contain = m.values().any(|&val| *val == *v);
        println!("{:?}", does_contain);
    }

    {
        let v = "twenty-two";
        let does_contain = m.values().any(|&val| *val == *v);
        println!("{:?}", does_contain);
    }
}


53. Join a list of strings

字符串连接

package main

import (
 "fmt"
 "strings"
)

func main() {

 x := []string{"xxx""bbb""aaa"}
 y := strings.Join(x, "&")

 fmt.Println(y)

}

输出

xxx&bbb&aaa

关于 strings.Joins[2]


fn main() {
    let x = vec!["Lorem""ipsum""dolor""sit""amet"];
    let y = x.join(", ");
    println!("{}", y);
}

输出

Lorem, ipsum, dolor, sit, amet

54. Compute sum of integers

计算整数之和

package main

import "fmt"

func main() {
 x := []int{123}
 s := 0
 for _, v := range x {
  s += v
 }
 fmt.Println(s)
}

输出

6


fn main() {
    let x: Vec<usize> = (0..=10_000).collect();
    
    eprintln!("Sum of 0-10,000 = {}", x.iter().sum::<usize>())
}

输出

Sum of 0-10,000 = 50005000


55. Convert integer to string

将整数转换为字符串

package main

import (
 "fmt"
 "strconv"
)

func main() {
 var i int = 1234
 s := strconv.Itoa(i)
 fmt.Println(s)
}

输出

1234

or

package main

import (
 "fmt"
 "strconv"
)

func main() {
 var i int64 = 1234
 s := strconv.FormatInt(i, 10)
 fmt.Println(s)
}

输出

1234

or

package main

import "fmt"
import "math/big"

func main() {
 var i int = 1234
 s := fmt.Sprintf("%d", i)
 fmt.Println(s)

 var j int = 5678
 s = fmt.Sprintf("%d", j)
 fmt.Println(s)

 var k *big.Int = big.NewInt(90123456)
 s = fmt.Sprintf("%d", k)
 fmt.Println(s)
}

输出

1234
5678
90123456

fn main() {
    let i = 123;
    let s = i.to_string();

    println!("{}", s);
}

输出

123

or

fn main() {
    let i = 123;
    let s = format!("{}", i);

    println!("{}", s);
}

输出

123


56. Launch 1000 parallel tasks and wait for completion

Fork-join : launch the concurrent execution of procedure f with parameter i from 1 to 1000. Tasks are independent and f(i) doesn't return any value. Tasks need not run all at the same time, so you may use a pool. Wait for the completion of the 1000 tasks and then print "Finished".

创建1000个并行任务,并等待其完成

package main

import (
 "fmt"
 "math/rand"
 "sync"
 "time"
)

func f(i int) {
 d := rand.Int() % 10000
 time.Sleep(time.Duration(d))
 fmt.Printf("Hello %v\n", i)
}

func main() {
 var wg sync.WaitGroup
 wg.Add(1000)
 for i := 1; i <= 1000; i++ {
  go func(i int) {
   f(i)
   wg.Done()
  }(i)
 }
 wg.Wait()
 fmt.Println("Finished")
}

输出

Hello 741
Hello 651
Hello 49
...(共计1000个)
Hello xxx

use std::thread;

fn f(i: i32) {
    i + 1;
}

fn main() {
    let threads: Vec<_> = (0..10).map(|i| thread::spawn(move || f(i))).collect();

    for t in threads {
     t.join();
    }
}

57. Filter list

Create list y containing items from list x satisfying predicate p. Respect original ordering. Don't modify x in-place.

过滤list中的值

package main

import "fmt"

type T int

func main() {
 x := []T{12345678910}
 p := func(t T) bool { return t%2 == 0 }

 y := make([]T, 0len(x))
 for _, v := range x {
  if p(v) {
   y = append(y, v)
  }
 }

 fmt.Println(y)
}

or

package main

import "fmt"

type T int

func main() {
 x := []T{12345678910}
 p := func(t T) bool { return t%2 == 0 }

 n := 0
 for _, v := range x {
  if p(v) {
   n++
  }
 }
 y := make([]T, 0, n)
 for _, v := range x {
  if p(v) {
   y = append(y, v)
  }
 }

 fmt.Println(y)
}

输出

[2 4 6 8 10]

fn main() {
    let x = vec![123456];

    let y: Vec<_> = x.iter()
        .filter(|&x| x % 2 == 0)
        .collect();

    println!("{:?}", y);
}

输出

[246]

58. Extract file content to a string

提取字符串的文件内容

package main

import "fmt"
import "io/ioutil"

func main() {
 f := "data.txt"
 b, err := ioutil.ReadFile(f)
 if err != nil {
  panic(err)
 }
 lines := string(b)

 fmt.Println(lines)
}

// Create file in fake FS of the Playground. init is executed before main.
func init() {
 err := ioutil.WriteFile("data.txt", []byte(`Un
Dos
Tres`
), 0644)
 if err != nil {
  panic(err)
 }
}

输出

Un
Dos
Tres

use std::fs::File;
use std::io::prelude::*;

fn main() -> Result<(), ()> {
    let f = "Cargo.toml";

    let mut file = File::open(f).expect("Can't open file.");
    let mut lines = String::new();
    file.read_to_string(&mut lines)
        .expect("Can't read file contents.");

    println!("{}", lines);

    Ok(())
}

or

use std::fs;

fn main() {
    let f = "Cargo.toml";

    let lines = fs::read_to_string(f).expect("Can't read file.");

    println!("{}", lines);
}

59. Write to standard error stream

Print the message "x is negative" to standard error (stderr), with integer x value substitution (e.g. "-2 is negative").

写入标准错误流

package main

import (
 "fmt"
 "os"
)

func main() {
 x := -2
 fmt.Fprintln(os.Stderr, x, "is negative")
}

输出

-2 is negative

fn main() {
    let x = -3;
    eprintln!("{} is negative", x);
}

输出

-3 is negative

60. Read command line argument

读取命令行参数

import "os"
x := os.Args[1]

use std::env;

fn main() {
    let first_arg = env::args().skip(1).next();

    let fallback = "".to_owned();
    let x = first_arg.unwrap_or(fallback);
    
    println!("{:?}", x);
}

输出

""


参考资料

[1]

When to use Rust and when to use Go: https://blog.logrocket.com/when-to-use-rust-when-to-use-golang/

[2]

strings.Joins: https://pkg.go.dev/strings#Join

本文由 mdnice 多平台发布

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/780389.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

高等数学❤️第一章~第三节~极限❤️连续函数的运算与初等函数的连续性~连续函数的运算

【精讲】高等数学中连续函数的运算 博主&#xff1a;命运之光的主页 专栏&#xff1a;高等数学 目录 【精讲】高等数学中连续函数的运算 导言 一、连续函数的运算规则 二、连续函数的性质 必需记忆知识点 例题&#xff08;用于熟悉高等数学中连续函数的运算&#xff09;…

【Java基础教程】(四十二)多线程篇 · 上:多进程与多线程、并发与并行的关系,多线程的实现方式、线程流转状态、常用操作方法解析~

Java基础教程之多线程 上 &#x1f539;本节学习目标1️⃣ 线程与进程&#x1f50d;关于多进程、多线程、并发与并行之间的概念关系&#xff1f; 2️⃣ 多线程实现2.1 继承 Thread 类2.2 实现 Runnable 接口2.3 多线程两种实现方式的区别2.4 利用 Callable 接口实现多线程2.5 …

Windows Server 2012 搭建网关服务器并端口转发

需求 使用 Windows server 作为Hyper-V 虚拟出许多虚拟机&#xff0c;基本上都分配了内网地址&#xff0c;现在需要这些虚拟机访问外网&#xff0c;或者外网直接访问这些虚拟机&#xff0c;必须配置一个网关服务器。我决定直接使用 Windows 的远程访问中的 NAT 服务来完成。 …

Ubuntu 上编译protobuf 指

欢迎大家关注我的B站主页MYVision_MY视界的个人空间-MYVision_MY视界个人主页-哔哩哔哩视频 下载protobuf GitHub - protocolbuffers/protobuf: Protocol Buffers - Googles data interchange format 根据需要从release 中下载指定的版本 下载完之后&#xff0c;根据提供的C…

Elasticsearch:使用 Elasticsearch ingest pipeline 丰富数据

在我之前的文章&#xff1a; Elasticsearch&#xff1a;如何使用 Elasticsearch ingest 节点来丰富日志和指标 Elasticsearch&#xff1a;enrich processor &#xff08;7.5发行版新功能&#xff09; 我有详细描述如何使用 ingest pipeline 来丰富数据。在今天的文章中里&am…

Stable Diffusion入门笔记(自用)

学习视频&#xff1a;20分钟搞懂Prompt与参数设置&#xff0c;你的AI绘画“咒语”学明白了吗&#xff1f; | 零基础入门Stable Diffusion保姆级新手教程 | Prompt关键词教学_哔哩哔哩_bilibili 1.图片提示词模板 2.权重&#xff08;提示词&#xff09; 无数字 (flower)//花的…

1 快速构建mybatis项目

1.1 使用Maven的quickstart框架 注意是不出现w的quickstart&#xff1a; 1.2 加入依赖 <dependencies><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.11</version><scope>test</s…

如何评测一个大语言模型?

编者按&#xff1a;大型语言模型&#xff08;Large language models, LLMs&#xff09;因其在学术界和工业界展现出前所未有的性能而备受青睐。随着 LLMs 在研究和实际应用中被广泛使用&#xff0c;对其进行有效评测变得愈发重要。近期已有多篇论文围绕大模型的评测进行研究&am…

二级分类基本实现步骤(小兔鲜儿)【Vue3】

二级分类 整体认识和路由配置 二级分类功能描述 配置二级路由 准备组件模版 <script setup></script><template><div class"container "><!-- 面包屑 --><div class"bread-container"><el-breadcrumb separa…

OA会议管理系统之会议发布(内含原型图项目介绍多功能下拉框源码)

目录 一、前言 1.什么是OA会议 2.OA会议项目背景 二、会议发布功能实现 1.功能介绍 2.功能分析 1.原型图以及数据表分析 2.查看官网搭建JSP页面 3.功能实现 1.实体类 2.dao层 3.JSP页面 4.Web层 4.案例演示 一、前言 1.什么是OA会议 会议OA指的是会议办公自动化…

设计模式结构型——外观模式

目录 什么是外观模式 外观模式的实现 外观模式的特点 什么是外观模式 外观模式&#xff08;Facade Pattern&#xff09;&#xff1a;又叫作门面模式&#xff0c;归属于结构型模式。外观模式定义了提供了定义了一个统一的高层接口&#xff0c;即为子系统中的一组接口提供一个…

PMP 数据收集工具与技术

数据收集工具与技术 (9个) 标杆对照 标杆对照是指将实际或计划的产品、流程和实践与其他可比组织的 做法进行比较&#xff0c;以便识别最佳实践、形成改进意见&#xff0c;并为绩效考核 提供依据。 头脑风暴 头脑风暴是一种数据收集和创意技术&#xff0c;主要用于在短时间…

苍穹外卖day05——Redis(被病毒入侵)+店铺营业状态设置

Redis被病毒入侵了 数据删光光然后只剩这四个玩意&#xff0c;乱下东西乱删东西&#xff0c;还好是docker部署&#xff0c;不然就寄了。 在服务器上部署redis记得一定要设置密码&#xff0c;不然被人扫肉鸡注入病毒整个服务器给你崩掉。 使用配置类的方式搭建相关程序 配置数…

【华为OD机试】经典屏保【2023 B卷|100分】

【华为OD机试】-真题 !!点这里!! 【华为OD机试】真题考点分类 !!点这里 !! 题目描述 DVD机在视频输出时,为了保护电视显像管,在待机状态会显示“屏保动画”, 如下图所示,DVD Logo在屏幕内来回运动,碰到边缘会反弹: 请根据如下要求,实现屏保Logo坐标的计算算法 1、屏…

[23] TriPlaneNet: An Encoder for EG3D Inversion

paper | code | project 总结&#xff1a; 任务是3D GAN Inversion&#xff0c;旨在找到给定图像的隐码/Tri-plane。现有方法可分为Optimizaiton-based methods和encoder-based methods。前者旨在通过损失找到最优隐码&#xff0c;后者旨在学习给定图片和隐码的映射关系。前者…

蚁剑--编码器的利用

先说下蚁剑编码器的作用&#xff0c;当使用蚁剑控制webshell向服务器发送数据包时&#xff0c;数据包中的body部分会按照编码器中定义的规则进行编码或者加密后在发送&#xff0c;这样就可以避免有比较明显的命令执行特征从而被WAF拦截。 我们平时遇到一些文件上传漏洞&#x…

maven的pom.xml文件解释(远程仓库阿里云)

<?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0"xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation"http://maven.apache.org/POM/4.0.0 http://ma…

layui上传文件弹出请求上传接口出现异常的终极解决方案(v2.68版本、ajax底层逻辑修改、debug快速定位)

layui不同版本情况系列 解决layUI请求上传接口出现异常的解决方案layui框架实战案例(3)&#xff1a;layui上传错误请求上传接口出现异常解决方案漏刻有时导入数据layUI上传提示“请求上传接口出现异常”的解决方案layui上传文件弹出请求上传接口出现异常的终极解决方案 layui上…

C语言库函数 — 错误信息报告函数

前言 本文介绍错误信息报告函数 错误信息报告函数的作用&#xff1a; 帮助程序员快速定位代码中的错误&#xff0c;以便更快地进行调试和修复问题。 文章目录 前言一、错误信息报告函数什么是错误信息报告函数错误信息报告函数的作用strerror函数介绍strerror函数使用错误码对应…

NLP多模型集成与比较

目录 数据集目的所用的两种词嵌入方式步骤随机读取10000条文本TF-IDF方法多模型比较CNN (用于比较 TF-IDF嵌入和词向量嵌入时的区别)LSTMBI-LSTM 数据集 10分类的新闻文本分类任务 目的 1.比较不同数据处理方式&#xff0c;词嵌入方式对任务的影响 2.比较相同处理方式下&…