学习笔记(06):19年并发编程及原理视频培训教程入门到精通-进程与线程的区别...

立即学习:https://edu.csdn.net/course/play/9827/208783?utm_source=blogtoedu

进程和线程的区别

   进程:是系统进行分配和管理资源的基本单位

   线程:进程的一个执行单元,是进程内调度的实体,是cpu调度和分派的基本单位,是比进程更小的独立运行的基本单位。线程也被称为轻量级进程,线程是程序执行的最小单位。

    一个程序至少一个进程,一给进程至少一个线程。

     进程有自己的独立地址空间,每启动一个进程,系统就会为它分配地址空间,建立数据表来维护代码段,堆栈段和数据段,这种操作非常昂贵。而线程是共享线程中的数据的,使用相同的地址空间,因此cpu切换一个线程的花费远比进程小得多,同时创建一个线程的开销也比进程要小得多。

      线程之间的通信更方便,同一进程下的线程共享全局变量,静态变量等数据,而进程之间的通信需要以通信的方式进行。

    如何处理好同步与互斥是编写多线程程序的难点。

    多进程程序更健壮,进程有独立的地址空间,一个进程崩溃后,在保护模式下不会对其他进程产生影响,而线程只是一个进程的不同执行路径。线程有自己的堆栈和局部变量,但线程之间没有单独的地址空间,所以可能一个线程出现问题,而导致整个程序出现问题。

发布了7 篇原创文章 · 获赞 6 · 访问量 31

猜你喜欢

转载自blog.csdn.net/weixin_45831970/article/details/104358634