并发与并行
并发:多个任务可以同时存在。程序在逻辑上可以实现多个任务同时存在,那么这个程序就是并发程序。并发程序在物理实现上既可以是并行,也可以是串行。
串行:单个处理器通过“任务切换”的方式,在一秒之内进行多次任务切换,给人一种任务并发的错觉。同一时间只有一个任务得到处理。
并行:多个任务在多个处理器中同时运行。多个任务在同一时间一起得到处理。
多进程并发与多线程并发
多进程并发:将应用程序分为多个进程。由于进程之间的资源并不能直接进行访问,进程之间的资源共享需要通过进行通信来完成,但是进程之间通信较为复杂。同时,操作系统为了对每个进程进行维护需要耗费更多资源,整体开销较大。但是,由于进程的资源保护,使用多进程并发更容易写出安全的并发程序。并且多进程并发可是实现远程连接,通过网络在不同的机器上运行进程。
多线程并发:单个进程运行多个线程。线程是轻量级的进程。多个线程之间共享内存地址。使用多线程并发开销更小,且更为灵活。但是为了保证数据一致性,将要做更多的额外工作。
一个简单的多线程例子
#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 =