进程管理


程序(process): 保存在硬盘、光盘等介质中的可执行代码和数据;是静态保存的代码
进程(thread) :在cpu及内存中运行的动态执行的程序代码
进程是程序运行的实例
同一个进程可能对应多个进程(如:同时开几个QQ)
线程: 有时被称为轻量级进程,是程序执行流的最小单位 (在进程中再划分实体)

每个运行中的程序就是一个进程,当一个程序运行时,内部可能包含了多个顺序执行流,每个顺序执行流就是一个线程

进程和线程的区别
它们是不同的操作系统资源管理方式。进程有独立的地址空间,一个进程崩溃后,在保护模式下不会对其它进程产生影响(如关掉一个QQ,其它并不会受影响); 而线程只是一个进程中的不同执行路径,线程有自己的堆栈和局部变量,但线程之间没有单独的地址空间,一个线程死掉就等于整个进程死掉。所以多进程的程序要比多线程的程序健壮,但在进程切换时,耗费资源较大,效率要差一些。对于一些要求同时进行并且又要共享某些变量的并发操作,只能用线程,不能用进程
1)地址空间和其它资源(如打开文件):进程间相互独立,同一进程的各线程间共享。
某进程内的线程在其它进程不可见
2)通信:进程间通信:共享内存、信号等;线程间可以直接读写进程数据段(如全局变量)
来进行通信——需要进程同步和互斥手段的辅助,以保证数据的一致性
3)调度和切换:线程上下文切换比进程上下文切换要块得多
4)在多线程OS中,进程不是一个可执行的实体

子进程和父进程
INIT进程是系统中第一个进程,PID永远为1
#命令& 放在后台运行

PID 进程号
PPID 父进程号码
:#ps aux | grep 2653
:#ps aux | grep 1778
:#bash
:#bash
:#pstree | grep bash
:#exit
:#exit

#ps 查看静态的进程统计信息
a all
u user
x
ax
aux
-e all
-l long (可看到父进程)
-f full
-el



VSZ:virtual memory size
RSS: resident set size

进程的五种状态 #man ps /state
R:run 可运行,随时会访问cpu
S:可中断睡眠,进程在某事发生前无事可做,需要的时候才被唤醒
D:不可中断睡眠,两个进程同时访问同一资源 等待输入输出
T:停止的进程,被挂起的进程
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值