进程是一个具有一定独立功能的程序的一次运行活动,是资源分配的最小单元。
进程与程序的比较:
程序是放到磁盘的可执行文件。
进程是指程序执行的实例。
进程的状态:
执行态:进程正在占用cpu,
就绪状态:进程以及具备一切条件,正在等待分配cpu的处理时间片
等待状态:进程不能使用cpu,若等待条件发生则可将其唤醒。
对Linux系统来说,这是一个多进程的系统,它的进程间具有并行性,互不干扰的特点。每个进程都是一个独立的运行单位,拥有各自的权利和责任。其中各个进程都运行在独立的虚拟地址空间。一个进程异常不会影响到其他进程。
进程互斥:
当有若干进程都要使用某一个共享资源时,任何时刻最多允许一个进程使用,其他要使用该资源的进程必须等待,直到占用该资源者释放了该资源为止。
一次只允许一个进程访问的资源称为临界资源。
进程中访问临界资源的那段程序代码称为临界区。
一组并发进程按一定的顺序执行的过程称为进程间的同步,具有同步关系的一组并发进程称为合作进程,合作进程间的互相发送的信号称为消息或事件。
下面有几个跟进程有关的函数:
#include<sys/types.h>
#include<unistd.h>
pid_t getpid(void)
获取本进程ID
pid_t getppid(void)
获取父进程ID
pid_t fork(void)
创建子进程
这个函数比较有意思。传说中的一二三:调用一次,返回两次,可能有三种返回值。
<0: 创建失败
=0:这个进程是子进程
>0:这个进程是父进程
与上面相似的一个函数:
pid_t vfork(void)
创建子进程,返回值一样,但与fork的区别有:
fork():子进程拷贝父进程的数据段,子父进程执行次序不确定。
vfork():子进程与父进程共享数据段,子进程先运行,父进程后运行。
#include<sys/types.h>
#include<sys/wait.h>
pid_t wait(int * status)
阻塞该进程,直到其某个子进程退出。
另外在加一些linux下与进程有关的命令吧:
1. 进程监控命令(ps):
要对进程进行监测和控制,首先必须要了解当前进程的情况,也就是需要查看当前进程,而ps命令就是最基本同时也是非常强大的进程查看命令。使用该命令可以 确定有哪些进程正在运行和运行的状态、进程是否结束、进程有没有僵死、哪些进程占用了过多的资源等等。总之大部分信息都是可以通过执行该命令得到的。
2. 改变进程优先级的命令(nice和renice):
该Shell命令最常用的使用方式为:nice [-n <优先等级>][执行指令],其中优先等级的范围从-20-19,其中-20最高,19最低,只有系统管理者可以设置负数的等级。
3. 列出当前系统打开文件的工具(lsof):
lsof(list opened files),其重要功能为列举系统中已经被打开的文件,如果没有指定任何选项或参数,lsof则列出所有活动进程打开的所有文件。众所周知,linux环境中任何事物都是文件,如设备、目录、sockets等。所以,用好lsof命令,对日常的linux管理非常有帮助。
4. 进程查找/杀掉命令(pgrep/pkill):
查找和杀死指定的进程, 他们的选项和参数完全相同, 这里只是介绍pgrep。
来源在这里,里面有更详细的操作方法:
http://www.bubuko.com/infodetail-1469579.html##1