> Linux教程 > Linux学习 >

Linux的进程,线程和轻量级进程

Linux有很多发行版本,很多公司的程序或者服务器都是跑在Linux系统上的,所以了解一些Linux进程和线程的东西还是很有必要的。接下来,我们会讨论Linux下进程,线程和轻量级进程的关系。
Linux进程
进程是一个很基本的概念,可以理解成一个程序运行的实例。可以说你在Linux上看到的所有东西都必然对应一个进程,Linux上的每一个任务也都是以进程的形式完成的。很简单,因为不管做什么,你总需要系统资源吧,无论是内存,IO操作等,这些都是内核提供的。而内核只能想进程提供这些系统资源,所以任何任务要运行都要包装成进程。

Linux线程
说白了,线程其实就是进程的执行流。如果一个进程只有一个执行流,那么就是一个单线程的程序。现在大部分的程序都不止一个执行流,也就是多线程的进程。Linux上的线程其实是通过轻量级进程(Light Weight Process, LWP)来实现的,可以说,Linux系统内核并不认识线程,所有的任务执行都是以进程的形式存在的。轻量级进程和进程最大的区别在于,轻量级进程之间共享地址空间,以及资源,比如打开的文件等。因为地址空间和资源在是共享的,所以我们就说这些进程是轻量级的进程。

可以说,linux下的线程其实就是轻量级进程。同样,对Java程序,我们通过new Thread().start()起动的线程都可以和系统上的线程对应起来,也可以说和轻量级进程一一对应。

线程和top
Linux系统下,我们可以通过top来查看进程的运行情况,同样线程的运行情况也可以使用top来运行:

top -p <pid> -H


-p指定进程Id,可以多次指定,或者用逗号分隔,-H表示显示说有的线程。

top -p 123 -p 124343 -H
top -p 123,12331 H


(责任编辑:IT)