Rust的入门篇(下)

这篇博客是rust入门篇下

45. 生命周期注释

// 生命周期// 下面代码不能通过编译
// longer 函数取 s1 和 s2 两个字符串切片中较长的一个返回其引用值
// 返回值引用可能会返回过期的引用
// fn longer(s1: &str, s2: &str) -> &str {
//     if s2.len() > s1.len() {
//         s2
//     } else {
//         s1
//     }
// }// 生命周期注释
// &i32        // 常规引用
// &'a i32     // 含有生命周期注释的引用
// &'a mut i32 // 可变型含有生命周期注释的引用fn longer<'a>(s1:&'a str, s2:&'a str)->&'a str{if s2.len()>s1.len(){s2} else {s1}
}fn main(){let r;{let s1 = "rust";let s2 = "ecmascript";r = longer(s1, s2);println!("{} is longer", r);}}

46. 生命周期2

结构体中使用字符串切片引用

// 结构体中使用字符串切片引用fn main(){struct Str<'a>{content: &'a str}let s = Str{content: "string_slice"};println!("s.content={}", s.content);}

47. 泛型 特性 和 生命周期的综合例子

// 泛型、特性与生命周期 一起来use std::fmt::Display;fn longest_with_an_announcement<'a, T>(x: &'a str, y: &'a str, ann: T)-> &'a str where T: Display{println!("Announcement! {}", ann);if x.len() > y.len(){x} else{y}
}fn main(){let r = longest_with_an_announcement("abcd", "efg", "hello");println!("longest {}", r);
}

48. 接收命令行参数

// 接收命令行参数fn main(){let args = std::env::args();println!("{:?}", args);// Args { inner: ["target\\debug\\greeting.exe"] }// 遍历for arg in args{// target\debug\greeting.exeprintln!("{}", arg);}}

49. 从命令行传入字符串

// 命令行输入输入一些字母 IO流
use std::io::stdin;fn main(){let mut str_buf = String::new();// 从命令行输入一些字符stdin().read_line(&mut str_buf).expect("failed to read line");println!("your input line is \n{}", str_buf);}

50. 从文件读入

// 从文件读取字符
use std::fs;fn main(){let text = fs::read_to_string("d:/hello.txt").unwrap();println!("{}", text);}

51. 读取文件

整个文件一次性读取

// 从文件读取字符
use std::fs;fn main(){let content = fs::read("D:/text.txt").unwrap();println!("{:?}", content);}

52. IO流

// 流读取
use std::fs::{self, File};
use std::io::prelude::*;fn main(){let mut buffer = [0u8; 5];let mut file = fs::File::open("d:/text.txt").unwrap();file.read(&mut buffer).unwrap();println!("{:?}", buffer);file.read(&mut buffer).unwrap();println!("{:?}", buffer);}

53. 文件写入

use std::fs;fn main(){// 文件写入fs::write("d:/text.txt", "FROM RUST PROGRAM").unwrap();
}

54. 文件末尾追加字符

use std::io::prelude::*;
use std::fs::OpenOptions;fn main()->std::io::Result<()>{let mut file = OpenOptions::new().append(true).open("d:/text.txt")?;file.write(b" APPEND WORD");Ok(())
}

55. 读写方式打开文件


use std::io::prelude::*;
use std::fs::OpenOptions;fn main()->std::io::Result<()>{let mut file = OpenOptions::new().read(true).write(true).open("d:/text.txt")?;file.write(b"COVER")?;Ok(())}

56. 集合一

集合的创建

// 集合创建
fn main(){let vector: Vec<i32> = Vec::new(); // 创建类型为 i32 的空向量let vector = vec![1, 2, 4, 8]; // 通过数组创建向量}

57. 向集合添加元素

使用push添加元素

// push 添加 元素
fn main(){let mut vector = vec![1, 2, 4, 8];vector.push(16);vector.push(32);vector.push(64);println!("{:?}", vector);}

58. 在集合末尾添加一个集合

// append 添加集合
fn main(){let mut v1:Vec<i32> = vec![1, 2, 4, 8];let mut v2:Vec<i32> = vec![16, 32, 64];v1.append(&mut v2);println!("{:?}", v1);}

59. 集合遍历和取元素


fn main(){let mut v = vec![1, 2, 4, 8];// 相对安全的取值方法println!("{}", match v.get(0) {Some(value)=>value.to_string(),None=>"None".to_string()});// 下标取值let v = vec![1, 2, 4, 8];println!("{}", v[1]);// 遍历let v = vec![100, 32, 57];for i in &v{println!("{}", i);}}

60. string字符串操作


fn main(){// 新建字符串let string = String::new();// 基础类型转成字符串let ont = 1.to_string();let float = 1.3.to_string();let slice = "slice".to_string();//  包含 UTF-8 字符的字符串let hello = String::from("السلام عليكم");let hello = String::from("Dobrý den");let hello = String::from("Hello");let hello = String::from("שָׁלוֹם");let hello = String::from("नमस्ते");let hello = String::from("こんにちは");let hello = String::from("안녕하세요");let hello = String::from("你好");let hello = String::from("Olá");let hello = String::from("Здравствуйте");let hello = String::from("Hola");// 字符串追加let mut s = String::from("run");s.push_str("oob");s.push_str("!");// + 拼接字符串let s1 = String::from("Hello, ");let s2 = String::from("world!");let s3 = s1 + &s2;// 使用format!宏let s1 = String::from("tic");let s2 = String::from("tac");let s3 = String::from("toe");let s = format!("{}-{}-{}", s1, s2, s3);let s = "hello";let len = s.len();// 中文字符长度let s = "你好";let len = s.len(); // 6 中文utf-8编码,一个字长3个字节println!("{}", len);// 中文字符正确长度let s = "你好";let len = s.chars().count(); // 2println!("{}", len);// 字符串遍历let s = String::from("hello中文");for c in s.chars(){println!("{}", c);}// 取单个字符let s = String::from("EN中文");let a = s.chars().nth(2); // Some('中')println!("{:?}", a); // 按索引截取字符串 不推荐 遇到中文有问题let s = String::from("EN中文"); let sub = &s[0..2]; // EN// let sub = &s[0..3]; // 报错了println!("{}", sub);}

61. hashmap

use std::collections::HashMap;fn main(){// 映射表操作let mut map = HashMap::new();map.insert("color", "red");map.insert("size", "10 m^2");println!("{}", map.get("color").unwrap());// 遍历映射表操作for p in map.iter(){println!("{:?}", p);/*("color", "red")("size", "10 m^2")*/}// 先判断key是否存在,然后才安全插入map.entry("color").or_insert("red");let mut map = HashMap::new();map.insert(1, "a");// 在已经确定有某个键的情况下直接修改对应的值if let Some(x) = map.get_mut(&1){*x = "b";}for p in map.iter(){println!("{:?}", p);}// (1, "b")}

62. 面向对象

second.rs

pub struct ClassName{field: i32,
}impl ClassName{pub fn new(value: i32)->ClassName{ClassName{field: value}}pub fn public_method(&self){println!("from public method");self.private_method();}fn private_method(&self){println!("from private method");}}

main.rs

mod second;
use second::ClassName;fn main(){let object = ClassName::new(1024);object.public_method();}

63. 并发编程1

use std::thread;
use std::time::Duration;fn spawn_function(){for i in 0..5{println!("spawned thread print {}", i);thread::sleep(Duration::from_millis(1));}
}fn main(){thread::spawn(spawn_function);for i in 0..3{println!("main thread print {}", i);thread::sleep(Duration::from_millis(1));}
}

64. 并发编程2 匿名函数

use std::thread;
use std::time::Duration;fn main(){// 闭包是可以保存进变量或作为参数传递给其他函数的匿名函数。闭包相当于 Rust 中的 Lambda 表达式,格式如下:/**|参数1, 参数2, ...| -> 返回值类型 {// 函数体}*/thread::spawn(||{for i in 0..5 {println!("spawned thread print {}", i);thread::sleep(Duration::from_millis(1));}});for i in 0..3 {println!("main thread print {}", i);thread::sleep(Duration::from_millis(1));}}

65. 匿名函数与参数传递

fn main(){// 匿名函数与参数传递let inc = |num: i32|->i32{num + 1};println!("inc(5) = {}", inc(5));let inc = |num|{num + 1};println!("inc(5) = {}", inc(5));}

66. 守护线程

use std::thread;
use std::time::Duration;// join 方法可以使子线程运行结束后再停止运行程序。
fn main(){let handle = thread::spawn(||{for i in 0..5{println!("spawned thread print {}", i);thread::sleep(Duration::from_millis(1));}});for i in 0..3{println!("main thread print {}", i);thread::sleep(Duration::from_millis(1));}handle.join().unwrap();/*main thread print 0spawned thread print 0main thread print 1spawned thread print 1spawned thread print 2main thread print 2spawned thread print 3spawned thread print 4*/}

67. 使用move进行所有权迁移

使用move让子线程访问主线程变量

use std::thread;fn main() {let s = "hello";let handle = thread::spawn(move || {println!("{}", s);});handle.join().unwrap();
}

68. 主线程与子线程之间的消息收发

// 消息传递
use std::thread;
use std::sync::mpsc;fn main(){let (tx, rx) = mpsc::channel();thread::spawn(move||{let val = String::from("hi");tx.send(val).unwrap();});let received = rx.recv().unwrap();println!("Got: {}", received);}

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

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

相关文章

亚马逊、虾皮、Lazada、速卖通、阿里国际等跨境电商平台怎么获取优质评价?

在跨境电商平台上&#xff0c;产品的评价直接影响卖家账户的评定因素&#xff0c;同时也影响产品页面的曝光量和流量&#xff0c;从而对产品销量产生影响&#xff0c;因此&#xff0c;产品评价的重要性不言而喻&#xff0c;除了产品的图片、描述、详情、广告和站外推广&#xf…

【LeetCode】不同路劲(动态规划)

不同路劲 题目描述算法流程编程代码 链接: 不同路劲 题目描述 算法流程 编程代码 class Solution { public:int uniquePaths(int m, int n) {vector<vector<int>> dp(m 1,vector<int>(n 1));dp[1][0] 1;for(int i 1;i < m;i){for(int j 1;j < n…

嵌入式基础知识-存储器

本篇介绍计算机存储硬件的一些基础知识&#xff0c;在嵌入式开发中&#xff0c;也同样适用。 1 计算机存储结构 存储器是计算机中的重要部件&#xff0c;理想的存储器应该是执行快&#xff0c;容量足&#xff0c;价格便宜等。但实际上&#xff0c;目前无法同时满足这些目标&a…

blender凹凸感和置换形变

一、怎么做出凹凸感 需要三个部分的内容&#xff1a; 1、一个基础的纹理&#xff1a;告诉计算机需要用一个什么样的纹理做凹凸&#xff0c;纹理一般采用黑白&#xff0c;在计算机里面&#xff0c;从 0 - 1之间的值可以用从黑到白之间不同的灰度来表示因此&#xff0c;有一张黑白…

【Java】Spring——创建Spring + 对Spring的存储 /读取对象操作

文章目录 前言一、创建Spring项目二、向Spring容器中存储 Bean 对象三、从Spring容器中读取 Bean 对象得到Spring上下文对象得到 Bean 对象 总结 前言 本人是一个普通程序猿!分享一点自己的见解,如果有错误的地方欢迎各位大佬莅临指导,如果你也对编程感兴趣的话&#xff0c;互…

英语翻译日语翻译待遇哪个好

如今&#xff0c;随着世界联系越来越紧密&#xff0c;市场上对于翻译业务的需求也越来越大。那么&#xff0c;针对比较热门的英语翻译与日语翻译&#xff0c;哪个语言翻译待遇好&#xff1f; 我们知道&#xff0c;英语作为全球使用频率最高的语言&#xff0c;业务量大市场需求大…

【用户体验分析报告】 按需加载组件,导致组件渲染卡顿,影响交互体验?组件拆包预加载方案来了!

首先&#xff0c;我们看一些针对《如何提升应用首屏加载体验》的文章&#xff0c;提到的必不可少的措施&#xff0c;便是减少首屏幕加载资源的大小&#xff0c;而减少资源大小必然会想到按需加载措施。本文提到的便是一个基于webpack 插件与 react 组件实现的一套研发高度自定义…

[Android 13]PowerManagerService系列1--启动流程和核心方法

hongxi.zhu 2023-7-28 Android 13 PowerManagerService(简称PMS)主要是负责协调、管理设备CPU资源&#xff0c;并提供功能接口给应用框架层或应用层申请获取CPU资源的一个服务&#xff0c;例如&#xff1a;亮灭屏、关机、WakeLock管理、Dreamland(屏保模式)、休眠时间等行为。 …

云原生落地实践的25个步骤

一、什么是云原生&#xff1f; 云原生从字面意思上来看可以分成云和原生两个部分。 云是和本地相对的&#xff0c;传统的应用必须跑在本地服务器上&#xff0c;现在流行的应用都跑在云端&#xff0c;云包含了IaaS,、PaaS和SaaS。 原生就是土生土长的意思&#xff0c;我们在开始…

基于OAI与Ueransim的5G网络切片平台构成简述

自定义多切片核心网构建 为了实现在同一台机器上同时对每一个切片启动一套单独的核心网&#xff0c;并且可以同时启动多套核心网&#xff0c;我们在官方提供的核心网模板的基础上进行适当的修改&#xff0c;扩展出其他可以正常运行的核心网&#xff0c;由此我们可以实现在同一…

Swagger之Hello World !

目录 ■1&#xff0e;前言・Swagger介绍 ■2&#xff0e;例子&#xff0c;如果基于Spring Boot项目&#xff0c;实现Swagger---非常简单 2&#xff0e;1&#xff0e;已有的SpringBoot项目 2&#xff0e;2&#xff0e;修改POM文件 2&#xff0e;3&#xff0e;添加Config文件…

DAY01_Spring简介IOC、DI入门案例Bean基础配置Bean实例化Bean生命周期依赖注入(DI配置)

目录 一 Spring1 Spring简介1.1 为什么要学1.2 学什么1.3 怎么学 2 初识Spring2.1 Spring家族2.2 Spring发展史 3 Spring体系结构问题导入3.1 Spring Framework系统架构图3.2 Spring Framework课程学习路线 4 Spring核心概念问题导入4.1 目前我们代码存在的问题4.2 核心概念 二…

拿捏--->最大公约数

文章目录 题目描述算法思路代码示例辗转相除法暴力穷尽法更相减损法Stein法 题目描述 给定两个数&#xff0c;求这两个数的最大公约数 例如&#xff1a; 输入&#xff1a;20 40 输出&#xff1a;20 算法思路 最大公约数&#xff1a;即两个数据中公共约数的最大者 代码示例…

分冶算法 剑指 07 重建二叉树 排序算法:剑指45 把数组排成最小的数 10-I 斐波那契数列

来记录几个注意事项 1.vector容器里利用find&#xff08;&#xff09;函数 不同于map&#xff08;map有find方法&#xff09;&#xff0c;vector本身是没有find这一方法&#xff0c;其find是依靠algorithm来实现的。 所以要包含头文件 #include <iostream> #include <…

SpringBoot 实现跨域的六种方式

目录 1.通过SpringSecurity方式配置 2.使用Spring提供的CorsFilter注入Bean&#xff08;推荐&#xff09; 3.使用注解CrossOrigin注解&#xff08;繁琐&#xff09; 4.通过ResponseBodyAdvice 实现跨域 5.通过HttpServletResponse设置跨域 6.通过WebMvcConfigurer 实现跨…

奔驰CAN FD嵌入式控制器开发硬件设计及应用趋势

CAN FD作为一种性能可靠、功能完善、成本合理的远程网络通信控制方式&#xff0c;集成CAN/CAN FD控制器的MCU、核心板、工控板及物联网解决方案已经被广泛应用到各个控制系统中&#xff0c;例如汽车电子、自动控制、智能大厦、电力系统、能源物流、智慧改装等各个领域。 中国经…

Postgresql警告日志的配置

文章目录 1.postgresql与日志有关的参数2.开启日志3.指定日志目录4.設置文件名format5.設置日志文件產出模式6.設置日志记录格式7.日誌輪換7.1非截斷式輪換7.2 截斷式輪換 8.日誌記錄內容8.1 log_statement8.2 log_min_duration_statement 9 輸出範本 1.postgresql与日志有关的…

如何使用Webman框架实现多语言支持和国际化功能?

如何使用Webman框架实现多语言支持和国际化功能&#xff1f; Webman是一款轻量级的PHP框架&#xff0c;提供了丰富的功能和扩展性&#xff0c;使得开发人员能够更加高效地开发Web应用程序。其中&#xff0c;多语言支持和国际化功能是Web应用程序中非常重要的一项功能&#xff…

SQL编写规范

文章目录 1.命名规范&#xff1a;2.库表设计&#xff1a;3.查询数据&#xff1a;4.修改数据&#xff1a;5.索引创建&#xff1a; 1.命名规范&#xff1a; 1.库名、表名、字段名&#xff0c;必须使用小写字母或数字&#xff0c;不得超过30个字符。 2.库名、表名、字段名&#…

251_多线程_创建一个多线程的图像处理应用,其中每个线程负责对一部分图像进行处理,然后将处理后的结果合并为最终图像

举一个更丰富的例子来说明多线程的用法。 我们将创建一个多线程的图像处理应用,其中每个线程负责对一部分图像进行处理,然后将处理后的结果合并为最终图像。 这个例子可以更好地展示多线程并发处理的优势。 假设有一个函数 processImageSection,它会对图像的一个特定区域进…