Rust 实战练习 - 5. 多线程,多进程,协程

目标:

  • 多进程
  • 多线程
  • Rust的协程

多进程

use std::process::{Command, Stdio};fn main() {println!("call new exe in process:");// netstat -ntlp  // 耗时很短,所以看不出效果// netstat -p     // 耗时很长,如果可以异步输出,就好了let out = Command::new("netstat").arg("-ntlp").output().expect("echo failed!");println!("{}",String::from_utf8_lossy(out.stdout.as_slice()));println!("\r\nWait child run over...\r\n");// 必须piped 才能父子进程通信// spawn 切换到后台,只返回句柄let o1 = Command::new("netstat").arg("-p").stdout(Stdio::piped()).spawn().expect("o1 error");let out1 = o1.stdout.expect("stat error");let o2 = Command::new("grep").arg("tcp").stdin(Stdio::from(out1)).stdout(Stdio::piped()).spawn().expect("o2 error");let out2 = o2.wait_with_output().expect("wait error");println!("{}",String::from_utf8_lossy(out2.stdout.as_slice()));
}

多线程

use std::{thread, time::Duration};fn main() {println!("call function in thread:");thread::spawn(||{for i in 1..10 {let t = thread::current(); // // ThreadId(2), Noneprintln!("Thread Id:{:?} - {:?}, count: {}.", t.id(),t.name(),i);thread::sleep(1*Duration::from_secs(1));}});for i in 100..113 {let t = thread::current(); // ThreadId(1), Some("main")println!("main Id:{:?} - {:?}, count: {}.", t.id(),t.name(), i);thread::sleep(1*Duration::from_secs(1));}// name and waitlet th = thread::Builder::new().name("wait-th".to_string()).spawn(||{for i in 1..10 {let t = thread::current(); // ThreadId(3), Some("wait-th")println!("main2 Id:{:?} - {:?}, count: {}.", t.id(), t.name(), i);thread::sleep(1*Duration::from_secs(1));}}).unwrap();th.join().unwrap();// thread_local! 针对一个全局变量,多个线程共享初始值// 大部分场景下可以使用线程局部变量替代// 或者使用第三方thread-local库,支持线程结束后收集结果
}

协程

对于golang语言,使用的是有栈协程。使用栈和上下文切换来执行异步代码逻辑的机制。

Rust通过await, async, Future 支持无栈协程。内部生成了一个状态机以保证代码正确的流程。虽然使用起来没有golang的方便,但胜在效率很高。(早期有类似go的绿色线程GreenThread,现在已经抛弃)

但是,rust没有提供官方的运行时,需要社区驱动。比如futures, tokio, std-.

https://rust-lang.github.io/async-book

use std::{thread, time::Duration};
use async_std::task; // 依赖第三方运行时 async-stdasync fn hello() {for i in 1..10{println!("[hello] id: {:?} - {:?}, {}.", thread::current().id(), task::current().id(), i);task::sleep(Duration::from_secs(1)).await;}
}async fn world(){for i in 1..15{println!("[world] id: {:?} - {:?}, {}.", thread::current().id(), task::current().id(),i);task::sleep(Duration::from_secs(1)).await;}
}fn main() {let _f1 = task::spawn(hello());task::block_on(world());
}

协程的并发需要依赖第三方库,目前支持1:N, N:M 模型,可以在一个线程池里完成N:M模型的并发。

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

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

相关文章

Android源码阅读WorkMangaer - 4

前言 由于笔者目前水平限制,表达能力有限,尽请见谅。 WorkManager 是 Android Jetpack 库的一部分,提供了一种向后兼容的方式来安排可延迟的异步任务,这些任务即使在应用退出或设备重启后也应该继续执行,它是 Androi…

Java中 List 集合,通过 Stream 流进行排序总结

一、数据准备 public class OrderTest {private String channelCode;private BigDecimal rate;// 省略 getter、setter、toString()、constructor }List<OrderTest> orderTestList new ArrayList<>();OrderTest z09 new OrderTest("Z09", new BigDeci…

C++细节

背景知识&#xff1a; 面向对象的编程中&#xff0c;类&#xff08;Class&#xff09;是创建对象的蓝图或模板&#xff0c;它包含了数据&#xff08;通常称为属性或变量&#xff09;和行为&#xff08;通常称为方法或函数&#xff09;。将数据封装为私有&#xff08;private&am…

VUE之首次加载项目缓慢

最近公司有个大型的项目&#xff0c;使用vue2开发的&#xff0c;但是最终开发完成之后&#xff0c;项目发布到线上&#xff0c;首次加载项目特别缓慢&#xff0c;有时候至少三十秒才能加载完成&#xff0c;加载太慢了&#xff0c;太影响用户体验了&#xff0c;最近研究了一下优…

tcp和udp分别是什么?udp和tcp的区别

TCP和UDP是计算机网络中常见的两种传输层协议&#xff0c;它们在实际应用中具有不同的特点和用途。本文将对TCP和UDP进行介绍&#xff0c;并分析它们之间的区别。 TCP和UDP分别是什么&#xff1f; TCP&#xff08;Transmission Control Protocol&#xff09; TCP是一种面向连…

架构整洁之道-读书总结

1 概述 1.1 关于本书 《架构整洁之道》&#xff08;Clean Architecture: A Craftsman’s Guide to Software Structure and Design&#xff09;是由著名的软件工程师Robert C. Martin&#xff08;又称为Uncle Bob&#xff09;所著。这本书提供了软件开发和架构设计的指导原则…

Spring Boot中实现对特定URL的权限验证:拦截器、切面和安全框架的比较

引言&#xff1a; 在开发Web应用程序时&#xff0c;对特定URL进行权限验证是一项常见的需求。在Spring Boot中&#xff0c;我们有多种选择来实现这一目标&#xff0c;其中包括使用拦截器、切面和专门的安全框架&#xff08;如Spring Security&#xff09;。本文将比较这三种方式…

SQL中常用的函数

explode 将一行转换成多行 collect_list 将多行转化成一行数据。 coalesce&#xff08;a1,a2&#xff09;指的取得是两者中不为空的那一列。 to_json 将数据集合转化成json格式

vue3 使用crypto-js 加密以及解密

安装 npm install crypto-js 在utils内创建cryptojs import CryptoJS from crypto-js/crypto-js; const key CryptoJS.enc.Utf8.parse(123123); // 密钥 后端提供 const iv CryptoJS.enc.Utf8.parse(); // 偏移量 /*** AES加密 &#xff1a;字符串 key iv 返回base64*/ ex…

绘图技巧 | 双变量映射地图可视化绘制方法

本期推文我们绘制不常见的双变量主题地图&#xff0c;该类地图可以很好的在地图上用颜色展示两个变量的信息&#xff0c;相较于单一变量映射地图&#xff0c;此类地图表达的信息更加丰富和全面。本期推文主要涉及的内容如下&#xff1a; 双变量映射地图(Bivariate Choropleth M…

深入C语言库:字符与字符串函数模拟实现

前言 C语言的库函数&#xff0c;是我们经常在编写程序所用到的函数&#xff0c;我们可以借用库函数去实现各种各样的功能&#xff0c;在本篇文章&#xff0c;我们介绍的是C语言中字符串和字符的相关库函数&#xff0c;以及他们的模拟实现&#xff0c;通过模拟实现我们可以深入…

以C++为核心语言的高频交易系统是如何做到低延迟的?

一、语言特性与性能优势 1. 高效执行效率&#xff1a; C是一种静态类型、编译型语言&#xff0c;其代码经过编译后直接生成机器码&#xff0c;无需像解释型或虚拟机语言那样在运行时进行额外的解析或字节码翻译&#xff0c;从而保证了极高的执行效率。C还提供了丰富的低级内存…

Anaconda管理python环境(windows系统)

目录 查看环境列表卸载环境 查看环境列表 conda env list卸载环境 这里的 envname 是环境名称 conda remove -n envname --all

Jmeter 聚合报告之 90% Line 正确理解

今天看了些关于Jmeter 聚合报告之 90% Line 的一些博客 关于90% Line 的算法各有各自的见解 。 90%Line可以用公式计算&#xff1a; 100/总个数每一个所占的百分比&#xff0c;90%/每一个所占的百分比90%Line的序号&#xff08;从小到大排&#xff09; 例如&#xff1a;1.2.3.…

PPT录制视频保存在哪?我来告诉你答案

在如今的信息化时代&#xff0c;ppt已经成为了工作中必不可少的工具。而ppt录制视频能够更好地展示ppt内容&#xff0c;方便观众随时随地观看。可是很多人不知道ppt录制视频保存在哪&#xff0c;本文将为您介绍ppt录制视频的保存位置&#xff0c;为读者提供关于ppt录屏的实用技…

[Linux]知识整理(持续更新)

前言 Linux的目录结构 Linux的目录结构是一个树型结构 Windows 系统可以拥有多个盘符, 如 C盘、D盘、E盘 Linux没有盘符这个概念, 只有一个根目录 /, 所有文件都在它下面 Linux路径的描述方式 第一章 基本命令 命令格式 例:ls –la /etc 说明: 1)个别命令使用不遵循…

【B树 B+树——数据结构】

B树 B树——数据结构 B树是一种自平衡的数据结构&#xff0c;常用于数据库和文件系统中进行索引和存储。B树具有以下特点&#xff1a; 多路平衡查找树&#xff1a;B树是一种多路查找树&#xff0c;即每个节点可以拥有多个子节点。这使得B树可以更高效地存储大量数据&#xff0…

ELMOS

where L W o L_{Wo} LWo​() is the o-th softmax classifer&#xff0c; L U o L_{Uo} LUo​() is the o-th projector 辅助信息 作者未提供代码

人力资源面试题

一&#xff0c;个人信息了解 1&#xff0c;请谈一下你自己的一些情况&#xff1b; 1&#xff0c;注意突出个人优势 在面试自我介绍中&#xff0c;不要讲过多的废话&#xff0c;而是应该直接突出个人的优势&#xff0c;通过个人的突出优势&#xff0c;这样才能够提升面试官的兴…

16:00面试,16:06就出来了,问的问题有点变态。。。

从小厂出来&#xff0c;没想到在另一家公司又寄了。 到这家公司开始上班&#xff0c;加班是每天必不可少的&#xff0c;看在钱给的比较多的份上&#xff0c;就不太计较了。没想到8月一纸通知&#xff0c;所有人不准加班&#xff0c;加班费不仅没有了&#xff0c;薪资还要降40%…