1.进程的定义和构成(由以下两点构成)
(1)一个内核对象,操作系统用它来管理进程。内核对象也是系统保存进程统计信息的地方。
(2)一个地址空间,其中包含所有可执行文件或DLL模块的代码和数据。此外,它还包括动 态 内 存分配,比如线程堆栈和堆的分配。
进程是有“惰性”的,进程要做任何事情,都必须让一个线程在它的上下文中运行。该线程负责执行进程地址空间包含的代码。事实上,一个进程可以有多个线程,所有线程都在进程的地址空间中“同时”执行代码。为此,每个线程都有它自己的一组CPU寄存器和它自己的堆栈。每一个进程创建第一个线程,称为主线程。然后这个线程再创建更多的线程,后者再创建更多的线程。。。。如果没有线程要执行进程地址空间包含的代码,进程就失去了继续存在的理由。这时,系统会自动销毁进程及其地址空间。
对于所有要运行的线程,操作系统会轮流为每个线程调度一些CPU时间。它会采用循环(轮询或轮流)方式,为每一个线程都分配时间片(称为“量”或者“量程”)即从而营造出所有线程都在“并发”运行的假象。(单CPU下)。多CPU下操作系统会采用更复杂的算法为线程分配CPU时间,实现真正的并发。