Linux并发(task_struct结构体)

来源:互联网 发布:淘宝定价 编辑:程序博客网 时间:2024/04/30 02:21

Linux下的进程也好,线程也罢,在内核中统统都以任务(task)的面目示人,他们用一样的内核数据结构来表示。

 

拓展:

内核中用一个非常大的结构体来表达进程或者线程(统称任务task),下面是这个结构体的掠影:

如果没什么意外,这个结构体可能是这个宇宙中最大的单个变量了,一个结构体就有好几k那么大,想想他包含了一个进程的所有信息,这么庞大也不足为怪了。LINUX内核代码纷繁复杂,千头万绪,这个结构体是系统进程在执行过程中所有涉及的方方面面的缩影,包括系统内存管理子系统、进程调度子系统、虚拟文件系统等等,以这个所谓的PCB为切入点,是一个很好的研究内核的窗口。

总之,当一个程序文件被执行的时候,内核将会产生这么一个结构体,来承载所有该活动实体日后运行时所需要的所有资源,随着进程的运行,各种资源被分配和释放,是一个动态的过程。

0 0
原创粉丝点击