博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Linux 进程
阅读量:5788 次
发布时间:2019-06-18

本文共 3273 字,大约阅读时间需要 10 分钟。

  进程作为资源分配和调度的基本单元,当进程被引进来后,线程作为系统调度执行的基本单元。

  与进程不同,同一进程的各个线程可以共享资源。

  linux运行中有就绪(Waiting),执行(Running)和停止(Stopped)三种基本状态。此外,linux还会产生一种不受欢迎的状态:僵死(Zombie)状态,通常称为Z状态。处于Z状态的进程已经死亡,但没有释放系统资源,包括内存和一些系统表等。在Linux操作系统中要手动清除处于Z状态的进程。

#include 
#include
int main(){ //获取自身所运行的进程ID printf("%d\n",(int)getpid()); //获取父进程ID printf("%d\n",(int)getppid()); return 0;}

创建进程:

pid_t fork();

ps命令:确定有哪些进程正在运行以及运行的状态。

ps a    显示当前终端机的程序ps -A   显示所有程序ps c    列出程序,并显示详细信息ps e    列出程序,显示环境变量ps -H   显示树状结构,表示结构之间的相互关系ps -N   显示所有程序,除了执行PS终端机下的程序之外ps  s   采用程序信号的格式显示程序状况ps  u   以用户为主的格式来显示程序状况ps  x   显示所有程序,不以终端机来区分

进程终止:

pid_t wait(int *status);

例子:

//      fork.c#include 
#include
#include
#include
int main(int argc, char **argv){ pid_t child_pid,pid; int status; child_pid=fork(); switch(child_pid) { case -1: printf("failed!\n"); break; case 0: printf("child pid is %d\n",(int)getpid()); break; default: printf("child pid is %d, parent pid is %d\n",(int)child_pid,(int)getpid()); //终止子进程 pid=wait(&status); if(WIFEXITED(status)) printf("child process exited with code %d\n",child_pid); else printf("child process terminated abnormally!\n"); break; } return 0;}

进程间通信:

在同一台计算机中的进程相互通信的方式主要有:管道(Pipe),信号(Signal),信号量(Semaphpre),消息队列(Message)和共享内存(Shared Memory)。

 信号:

void (*signal(int signum, void (*handler)(int)))(int)//signum指出要设置处理方法的信号//handler是要处理的函数
int sigaction(int signum, const struct sigaction *act, struct sigaction *oldact)//signum为信号的值//act指定了对特定信号的处理//oldact保存原来相应的处理

可以通过kill -l命令来查看所有信号。

例子:

#include
#include
#include
#include
void signalHandle(int signal){ switch(signal) { case SIGHUP: printf("catch signal:sighup(%d)\n",signal); break; case SIGINT: printf("catch signal:sigint(%d)\n",signal); break; case SIGQUIT: printf("catch signal:sigquit(%d)\n",signal); break; case SIGALRM: printf("catch signal:sigalrm(%d)\n",signal); break; default: printf("unknow signal:%d",signal); break; }}int main(){ int sec_delay=5; printf("current process id:%d\n",(int)getpid()); signal(SIGINT,signalHandle); signal(SIGQUIT,signalHandle); signal(SIGALRM,signalHandle); alarm(sec_delay); while(1) pause(); return 0;}//sighup-->ctrl+\//sigint-->ctrl+c

管道:

  管道分为普通管道(Pipe)和命名管道(FIFO)。它们都是通过内核缓冲区按先进先出的方式进行数据传输,管道一端顺序地写入数据,另一端顺序地读入数据。管道是半双工的,要进行双方通信,要建立两个管道。

  主要介绍命名管道:

int mkfifo(const char* pathname, mode_t mode)//pathname为文件路径名//mode设置新创建的FIFO文件的文件许可权控制位的值为指定的方式值。//一般的文件的I/0函数,如read(),write(),close()等,都可以用于FIFO

例子:

 未完待续~~~

 

转载于:https://www.cnblogs.com/coder2012/archive/2013/03/31/2988526.html

你可能感兴趣的文章
Uva 839 Not so Mobile
查看>>
30款超酷的HTTP 404页面未找到错误设计
查看>>
程序猿必备 MyEclipse2013-2014系列
查看>>
java中ArrayList 、LinkList区别
查看>>
Spring ’14 Wave Update: Installing Dynamics CRM on Tablets for Windows 8.1
查看>>
利用rand7()构造rand10()
查看>>
MySQL 备份与恢复
查看>>
吃午饭前,按书上的代码写会儿--Hunt the Wumpus第一个版本
查看>>
easyui中combobox的值改变onchang事件
查看>>
Eclipse魔法堂:任务管理器
查看>>
一周自学动态站点设计
查看>>
poj万人题
查看>>
Android-Universal-Image-Loader
查看>>
Android 从硬件到应用:一步一步向上爬 4 -- 使用 JNI 方法调硬件驱动
查看>>
TEST
查看>>
loadrunner 的Administration Page里面设置
查看>>
程序员喜欢怎样的职位描述?(转)
查看>>
威胁快报|ProtonMiner挖矿蠕虫扩大攻击面,加速传播
查看>>
PAT A1116
查看>>
App上架/更新怕被拒? iOS过审“避雷秘籍”请查收
查看>>