"); //-->
进程概念
进程是表示资源分配的基本单位,又是调度运行的基本单位。例如,用户运行自己的程序,系统就创建一个进程,并为它分配资源,包括各种表格、内存空间、磁盘空间、I/O设备等。然后,把该进程放人进程的就绪队列。进程调度程序选中它,为它分配CPU以及其它有关资源,该进程才真正运行。所以,进程是系统中的并发执行的单位。
在Mac、Windows NT等采用微内核结构的操作系统中,进程的功能发生了变化:它只是资源分配的单位,而不再是调度运行的单位。在微内核系统中,真正调度运行的基本单位是线程。因此,实现并发功能的单位是线程。
线程概念
线程是进程中执行运算的最小单位,亦即执行处理机调度的基本单位。如果把进程理解为在逻辑上操作系统所完成的任务,那么线程表示完成该任务的许多可能的子任务之一。例如,假设用户启动了一个窗口中的数据库应用程序,操作系统就将对数据库的调用表示为一个进程。假设用户要从数据库中产生一份工资单报表,并传到一个文件中,这是一个子任务;在产生工资单报表的过程中,用户又可以输人数据库查询请求,这又是一个子任务。这样,操作系统则把每一个请求――工资单报表和新输人的数据查询表示为数据库进程中的独立的线程。线程可以在处理器上独立调度执行,这样,在多处理器环境下就允许几个线程各自在单独处理器上进行。操作系统提供线程就是为了方便而有效地实现这种并发性
引入线程的好处
(1)易于调度。
(2)提高并发性。通过线程可方便有效地实现并发性。进程可创建多个线程来执行同一程序的不同部分。
(3)开销少。创建线程比创建进程要快,所需开销很少。。
(4)利于充分发挥多处理器的功能。通过创建多线程进程(即一个进程可具有两个或更多个线程),每个线程在一个处理器上运行,从而实现应用程序的并发性,使每个处理器都得到充分运行。
进程和线程的关系
(1)一个线程只能属于一个进程,而一个进程可以有多个线程,但至少有一个线程。
(2)资源分配给进程,同一进程的所有线程共享该进程的所有资源。
(3)处理机分给线程,即真正在处理机上运行的是线程。
(4)线程在执行过程中,需要协作同步。不同进程的线程间要利用消息通信的办法实现同步。
专栏文章内容及配图由作者撰写发布,仅供工程师学习之用,如有侵权或者其他违规问题,请联系本站处理。 联系我们
相关推荐
Google、三星、Arm和开放媒体联盟联手打造Eclipsa Audio,重新定义音频体验
MPLAB® X IDE 编译调试(下)
由Arm驱动的NVIDIA Project DIGITS为数百万开发者带来高性能AI算力
Ceva通过新合作伙伴扩展嵌入式人工智能NPU生态系统
请教:Tonardo bootrom_uncmp后生成的最终文件是什么,怎么有那么多*.o的文件
飞思卡尔汽车电子半导体3-方案 (中文)
基于PIC32的蜂窝网机器到机器(M2M)通信解决方案
国产FPGA SoC芯选择,米尔安路飞龙核心板重磅发布
Crucial英睿达扩大旗下内存和存储产品组合,为消费者带来崭新性能体验
飞思卡尔汽车电子半导体 (中文)
[消费类电子]解决方案通报
电磁感应演示器
电磁振荡演示器(NE555、CD4017)
电流方向演示器(CD4089、CD4017)
Ceva嵌入式人工智能NPU在AIoT和MCU市场势如破竹赢得多个客户设计,并得到增强的AI Software Studio支持
MPLAB® X IDE 编译调试(上)
[讨论]VXworks下如何实现对USB设备的读写?
开发一套dsp系统,需要买那些东西?
是德科技推出设计紧凑的、适用于软件定义汽车的汽车网络测试解决方案,扩展Novus产品组合
基于PIC32的低成本图形解决方案
[原创]
Microchip WiFi 模塊(MRF24WB0Mx系列) 的連線種類與方法—WiFi介紹与Infrastructure Mode
没有调用muxBind 就用muxSend发送数据可以吗
想要BMS高效稳定?电流感应电阻解决方案了解下!
搭载国产最新8nm制程SOC,米尔RK3576开发板初体验!
思特威全新推出物联网系列3MP高性能图像传感器SC301HIOT
桥式整流演示电路(NE555)
脉冲占空比演示电路
轮胎压力监控系统应用参考指南 (中文)
飞思卡尔汽车电子半导体2-产品 (中文)