C++并发编程(一):并发与并行,一个简单的多线程例子

并发与并行

并发:多个任务可以同时存在。程序在逻辑上可以实现多个任务同时存在,那么这个程序就是并发程序。并发程序在物理实现上既可以是并行,也可以是串行。

串行:单个处理器通过“任务切换”的方式,在一秒之内进行多次任务切换,给人一种任务并发的错觉。同一时间只有一个任务得到处理。

并行:多个任务在多个处理器中同时运行。多个任务在同一时间一起得到处理。

多进程并发与多线程并发

多进程并发:将应用程序分为多个进程。由于进程之间的资源并不能直接进行访问,进程之间的资源共享需要通过进行通信来完成,但是进程之间通信较为复杂。同时,操作系统为了对每个进程进行维护需要耗费更多资源,整体开销较大。但是,由于进程的资源保护,使用多进程并发更容易写出安全的并发程序。并且多进程并发可是实现远程连接,通过网络在不同的机器上运行进程。

多线程并发:单个进程运行多个线程。线程是轻量级的进程。多个线程之间共享内存地址。使用多线程并发开销更小,且更为灵活。但是为了保证数据一致性,将要做更多的额外工作。

一个简单的多线程例子

#include <thread>
#include <iostream>
using namespace std;

void hello(){
    for(int i = 0; i < 10; i++)
        cout << "hello concurrent \n";
}

int main(){
    thread t(hello);
    for(int i = 0; i < 10; i++)
        cout << "main concurrent \n";
    t.join();

}

1、c++提供了标准库thread来管理线程。thread库用于线程的管理,对于共享数据和通信的操作需要使用其他的库。

2、thread t(hello); 启动了一个新的线程,并以hello函数作为起始函数。

3、t.join();让main线程等待t线程结束。否则会报terminate called without an active exception。不加join的话,main线程可能提前结束后,回收资源。但是此时新线程还没有结束,还会对已经销毁的资源进行访问,引发错误。

main concurrent 
hello concurrent 
hello concurrent 
hello concurrent 
hello concurrent 
hello concurrent 
hello concurrent 
hello concurrent 
hello concurrent 
main concurrent 
main concurrent 
main concurrent 
main concurrent 
main concurrent 
main concurrent 
main concurrent 
main concurrent 
hello concurrent 
hello concurrent 
main concurrent 

从结果可以看出,main线程和t线程同时在进行各自的输出。

  • 5
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值