进程
说的直白一点,一个exe文件执行就会创建一个进程,这是系统自行创建的。调度和资源分配都是有系统完成的。
线程
- 首先,线程是由进程创建的,一个进程可以创建一个主线程,主线程结束进程就随之结束了。
- 在主线程执行的同时,可以手动创建子线程,子线程可以执行主线程之外的程序,主线程随着main函数的执行而执行,结束而结束。主线程结束就意味着这个进程结束,在进程中创建的一些子进程也全部都结束了。
- 子线程和主线程之间可以并发执行,提高执行效率。
- 但是线程也不是越多越好,每一个线程都需要独立的堆栈空间,而且线程之间的切换需要耗费时间和空间。
- 具体的线程数要根据系统的资源情况而定。
- 由于以上主线程和子线程的关系,如果要子线程顺利运行,就要保证主线程一直保持运行。
并发
并发的实现手段主要有两个,多进程并发和多线程并发
多进程
电脑上同时运行Word和浏览器就是=两个进程的并发,
进程之间的通讯手段有:同一电脑上(管道、文件、消息队列、共享内存),不同电脑上(socket通讯技术)
多线程
- 多线程就是在一个进程中创建了多个线程
- 感觉像轻量级的进程,每一个线程都有自己独立的运行路径,但是同一个 进程中的线程是共享地址空间的(共享内存),全局变量、指针、引用都 可以在线程之间传递。
- 使用多线程的开销要小于多进程。
- 但是多线程(共享内存)也会带来数据一致性的问题。
- 虽然多进程和多线程可以混合使用,但是优先考虑多线程并发。