Rust并发编程安全高效的处理并发是Rust诞生的目的之一,主要解决的是服务器高负载承受能力。并发(concurrent)的概念是指程序不同的部分独立执行,这与并行(parallel)的概念容易混淆,并行强调的是"同时执行"。并发往往会造成并行。本章讲述与并发相关的编程概念和细节。线程线程(thread)是一个程序中独立运行的一个部分。线程不同于进程(process)的地方是线程是程序以内的概念,程序往往是在一个进程中执行的。在有操作系统的环境中进程往往被交替地调度得以执行,线程则在进程以内由程序进行调度。由于线程并发很有可能出现并行的情况,所以在并行中可能遇到的死锁、延宕错误常出现于含有并发
Rust面向对象面向对象的编程语言通常实现了数据的封装与继承并能基于数据调用方法。Rust不是面向对象的编程语言,但这些功能都得以实现。封装封装就是对外显示的策略,在Rust中可以通过模块的机制来实现最外层的封装,并且每一个Rust文件都可以看作一个模块,模块内的元素可以通过pub关键字对外明示。这一点在"组织管理"章节详细叙述过。"类"往往是面向对象的编程语言中常用到的概念。"类"封装的是数据,是对同一类数据实体以及其处理方法的抽象。在Rust中,我们可以使用结构体或枚举类来实现类的功能:实例pubstructClassName{ pubfield:Type,}pubimplClassNa
Rust面向对象面向对象的编程语言通常实现了数据的封装与继承并能基于数据调用方法。Rust不是面向对象的编程语言,但这些功能都得以实现。封装封装就是对外显示的策略,在Rust中可以通过模块的机制来实现最外层的封装,并且每一个Rust文件都可以看作一个模块,模块内的元素可以通过pub关键字对外明示。这一点在"组织管理"章节详细叙述过。"类"往往是面向对象的编程语言中常用到的概念。"类"封装的是数据,是对同一类数据实体以及其处理方法的抽象。在Rust中,我们可以使用结构体或枚举类来实现类的功能:实例pubstructClassName{ pubfield:Type,}pubimplClassNa
Rust集合与字符串集合(Collection)是数据结构中最普遍的数据存放形式,Rust标准库中提供了丰富的集合类型帮助开发者处理数据结构的操作。向量向量(Vector)是一个存放多值的单数据结构,该结构将相同类型的值线性的存放在内存中。向量是线性表,在Rust中的表示是Vec。向量的使用方式类似于列表(List),我们可以通过这种方式创建指定类型的向量:letvector:Vec=Vec::new();//创建类型为i32的空向量letvector=vec![1,2,4,8];//通过数组创建向量我们使用线性表常常会用到追加的操作,但是追加和栈的push操作本质是一样的,所以向量只有pus
Rust集合与字符串集合(Collection)是数据结构中最普遍的数据存放形式,Rust标准库中提供了丰富的集合类型帮助开发者处理数据结构的操作。向量向量(Vector)是一个存放多值的单数据结构,该结构将相同类型的值线性的存放在内存中。向量是线性表,在Rust中的表示是Vec。向量的使用方式类似于列表(List),我们可以通过这种方式创建指定类型的向量:letvector:Vec=Vec::new();//创建类型为i32的空向量letvector=vec![1,2,4,8];//通过数组创建向量我们使用线性表常常会用到追加的操作,但是追加和栈的push操作本质是一样的,所以向量只有pus
Rust文件与IO本章介绍Rust语言的I/O操作。接收命令行参数命令行程序是计算机程序最基础的存在形式,几乎所有的操作系统都支持命令行程序并将可视化程序的运行基于命令行机制。命令行程序必须能够接收来自命令行环境的参数,这些参数往往在一条命令行的命令之后以空格符分隔。在很多语言中(如Java和C/C++)环境参数是以主函数的参数(常常是一个字符串数组)传递给程序的,但在Rust中主函数是个无参函数,环境参数需要开发者通过std::env模块取出,过程十分简单:实例fnmain(){ letargs=std::env::args(); println!("{:?}",args);}现在直接运
Rust文件与IO本章介绍Rust语言的I/O操作。接收命令行参数命令行程序是计算机程序最基础的存在形式,几乎所有的操作系统都支持命令行程序并将可视化程序的运行基于命令行机制。命令行程序必须能够接收来自命令行环境的参数,这些参数往往在一条命令行的命令之后以空格符分隔。在很多语言中(如Java和C/C++)环境参数是以主函数的参数(常常是一个字符串数组)传递给程序的,但在Rust中主函数是个无参函数,环境参数需要开发者通过std::env模块取出,过程十分简单:实例fnmain(){ letargs=std::env::args(); println!("{:?}",args);}现在直接运
Rust生命周期Rust生命周期机制是与所有权机制同等重要的资源管理机制。之所以引入这个概念主要是应对复杂类型系统中资源管理的问题。引用是对待复杂类型时必不可少的机制,毕竟复杂类型的数据不能被处理器轻易地复制和计算。但引用往往导致极其复杂的资源管理问题,首先认识一下垂悬引用:实例{ letr; { letx=5; r=&x; } println!("r:{}",r);}这段代码是不会通过Rust编译器的,原因是r所引用的值已经在使用之前被释放。上图中的绿色范围'a表示r的生命周期,蓝色范围'b表示x的生命周期。很显然,'b比'a小得多,引用必须在值的生命周期以内才有效。一直
Rust生命周期Rust生命周期机制是与所有权机制同等重要的资源管理机制。之所以引入这个概念主要是应对复杂类型系统中资源管理的问题。引用是对待复杂类型时必不可少的机制,毕竟复杂类型的数据不能被处理器轻易地复制和计算。但引用往往导致极其复杂的资源管理问题,首先认识一下垂悬引用:实例{ letr; { letx=5; r=&x; } println!("r:{}",r);}这段代码是不会通过Rust编译器的,原因是r所引用的值已经在使用之前被释放。上图中的绿色范围'a表示r的生命周期,蓝色范围'b表示x的生命周期。很显然,'b比'a小得多,引用必须在值的生命周期以内才有效。一直
Rust泛型与特性泛型是一个编程语言不可或缺的机制。C++语言中用"模板"来实现泛型,而C语言中没有泛型的机制,这也导致C语言难以构建类型复杂的工程。泛型机制是编程语言用于表达类型抽象的机制,一般用于功能确定、数据类型待定的类,如链表、映射表等。在函数中定义泛型这是一个对整型数字选择排序的方法:实例fn max(array: &[i32]) -> i32 { let mut max_index = 0; let mut i = 1; while i array.len() { if array[i] > array[max_index] {