Rust——并发/并行


1.并发和并行理解

  比如老师布置了10个不同的任务,小明一个人依次处理这10个任务;另外一种是小明和同学校花一起依次各处理5个任务。第一种处理方式就是我们理解的并发处理,第二种就是我们理解的并行处理。假设小明/小花的处理能力完全一致,明显第二种方式的处理效率为第一种处理方式的两倍

并发处理和并行处理都是对“多任务”进行处理,并发是轮流处理,并行是同时处理

a.并发处理

  并发处理关键:快速轮换处理不同的任务,给人以所有任务同时在运行的假象

  并发系统支持2个及以上多个线程的同时存在,但是多个线程之间要轮流运行

b.并行处理

  并行系统支持2个及以上多个线程的同时运行,系统中的每个线程都单独分配到一个独立的处理器核上

2.线程

  Rust中通过std::thread::spawn函数创建新线程

fn spawn_f(){
    for i in 0..5{
        println!("spawned thread print {}",i);
        thread::sleep(Duration::from_millis(1));
    }
}

fn main() {
    thread::spawn(spawn_f);

    for i in 0..5{
        println!("main thread print {}",i);
        thread::sleep(Duration::from_millis(1));
    }
    
}

  输出结果:

   若程序更改如下:

fn spawn_f(){
    for i in 0..5{
        println!("spawned thread print {}",i);
        thread::sleep(Duration::from_millis(1));
    }
}

fn main() {
    thread::spawn(spawn_f);

    for i in 0..4{    //更改此处
        println!("main thread print {}",i);
        thread::sleep(Duration::from_millis(1));
    }
    
}

  输出结果如下:

  从以上程序可以看出,主程序结束后,线程也结束运行,没有输出打印5次

  若要实现子线程完全打印,我们可以使用Join方法,代码更改如下:

fn spawn_f(){
    for i in 0..5{
        println!("spawned thread print {}",i);
        thread::sleep(Duration::from_millis(1));
    }
}

fn main() {
    let handle = thread::spawn(spawn_f);

    for i in 0..3{
        println!("main thread print {}",i);
        thread::sleep(Duration::from_millis(1));
    }
    handle.join().unwrap();
}

  运行后结果如下:

  join方法使子线程运行结束后再停止运行程序