Linux进程编程
2015-07-27 10:57
603 查看
一、与进程相关的系统函数 1.getpid #include<sys/types.h> /*提供pid_t类型的定义*/ #include<unistd.h> /*提供函数的定义*/ pid_t getpid(void); /*返回值为当前进程的进程ID*/ 2.getppid #include<sys/types.h> /*提供pid_t类型的定义*/ #include<unistd.h> /*提供函数的定义*/ pid_getppid(void); /*返回当前进程的父进程的ID*/ 3.fork 作用:克隆一个进程。当一个进程调用fork函数,完成后就出现两个一模一样的进程,由此得到一个新的进程。 新产生的进程成为子进程,调用fork的进程成为父进程。 子进程拷贝父进程的数据段,代码段,父子进程的执行次序不确定(就看哪个进程执行的块)。 fork函数调用后,会返回两个值: 在父进程中,fork返回新创建的子进程的ID 在子进程中,fork返回0 出错时,返回-1。 #include<sys/types.h> /*提供pid_t类型的定义*/ #include<unistd.h> /*提供函数的定义*/ pid_t fork(void); 4.1 exit #include<stdlib.h> void exit(int status); exit系统调用用来终止进程。带有一个整型的status参数,可以利用这个参数传递进程结束时的状态。 如果status为0,表示正常结束,其他值表示出现了错误,进程非正常结束。 在实际编程中,可以利用wait系统调用接收子进程的返回值,从而针对不同的情况进行处理。 4.2 _exit #include<unistd.h> void _exit(int status); _exit函数作用简单,直接使进程停止运行,清除使用的内存空间,销毁其在内核中的各种数据结构。 与exit函数相比,exit对_exit作了包装。exit调用时,会检查文件打开情况,把文件缓冲区内容写回文件,清理I/O缓冲区。 _exit不会处理I/O缓冲区。 eg: /*exit_test.c*/ #include<stdlib.h> int main(void) { printf("output begin\n"); printf("content in buffer"); exit(0); return 0; } ./exit_test 输出; output begin content in buffer /*_exit_test.c*/ #include<stdlib.h> int main(void) { printf("output begin\n"); printf("content in buffer"); _exit(0); return 0; } ./_exit_test 输出; output begin 验证结果: _exit(0)执行时,未对标准I/O做处理,缓冲区里的内容丢失。 管道,用于进程间的通信。从管道的一端顺序的写入数据,从另一端顺序地读出数据。 读写位置都是自动增加的,数据读一次之后就释放。在缓冲区写满时,由相应规则控制读写进程进入等待队列。 当空缓冲区有写入数据或满的缓冲区有数据读出时,就唤醒等待队列中的写进程继续读写。 管道两端分别用描述子fd[0]和fd[1]来描述,管道两端的任务划分是固定的,fd[0]为读端,fd[1]为写端。不可混用。 管道的性质: 1.只支持单向数据流 2.只能用于有亲缘关系的进程之间 3.无命名字 4.管道缓冲区有限(只存在于内存) 5.管道传送的是无格式的字节流,读写双方必须事先约定好数据格式。 5.pipe #include<unistd.h> int pipe(int fd[2]); 7.mknod #include<sys/types.h> //数据类型头文件 #include<sys/stat.h> //函数头文件 int mknod(char* pathname, mode_t mode, dev_t dev); 8.signal #include<signal.h> void (*signal(int signum, void(* handler)(int))); 9.kill #include<signal.h> int kill(pid_t pid, int sig); 向进程号为pid的进程发送sig信号。 /******************fork()*******************************/ #include<stdio.h> #include<sys/types.h> #include<unistd.h> int main(){ pid_t pid; pid = fork(); if(pid<0) printf("error in fork!"); else if(pid == 0) printf("I am the child process, my process ID is %d\n",getpid()); else printf("I am the parent process, my process ID is %d\n",getpid()); return 0; } /******************end**********************************/ 运行程序后,得到的结果,操作环境Fedora 14 内核2.6
相关文章推荐
- linux设置系统时间
- linux设置系统时间
- 深入理解Linux内核---进程
- 浅谈 linux 多线程编程和 windows 多线程编程的异同
- 对于用u盘安装CentOS后不插u盘就无法开启的解决过程
- linux下查看文件大小的命令
- LINUX关闭防火墙
- LINUX关闭防火墙
- linux解压缩tar,gz等各种文件的命令
- Linux命令详解 -- uname
- linux rz命令上传文件失败处理方法
- centos查看哪些包提供指定头文件
- centos查看哪些包提供指定头文件
- linux进程的介绍和管理
- linux进程的介绍和管理
- Linux内核线程
- Linux mkdir、tar 和 kill 命令的 4 个有用小技巧
- linux使用root登录
- CentOS6.5系统下RPM包安装MySQL5.6
- 【转】linux C++ 获取文件信息 stat函数详解