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 =
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值