Linux进程编程

一、与进程相关的系统函数
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

运行程序后,得到的结果,操作环境Fedora 14 内核2.6

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值