1.
fd:在形式上是一个非负整数.实际上他是一个索引值、指向kernal为每一个进程所维护的该进程打开文件的记录表.
当程序打开一个文件或者创建一个新文件的时候kernal向进程返回一个文件描述符。
优点:兼容POSIX标准,许多系统调用都依赖于它;缺点:不能移植到unix之外的系统上去
fp:FILE*指针变量标识符
优点:是C语言的通用格式,便于移植
2.
vfork:使用方法同fork差不多,也适用于创建子进程
vofork特点:
1)在子进程调用exec或exit之前,它在父进程的空间里运行,会改变父进程的数据段、栈和堆
eg:
int g_val=;
int main()
{
pid_t id=vfork();
if(id<){
perror("vfork");
return ;
}
else if(id==){//child
g_val=;
printf("child:pid:%d ppid:%d,g_val:%d,&g_val:%p\n",\
getpid(),getppid(),g_val,&g_val);
exit();
}
else{
printf("father:pid:%d,ppid:%d,g_val:%d,&g_val:%p\n",\
getpid(),getppid(),g_val,&g_val);
}
return ;
}
子进程改变了父进程的值(改变了父进程看到的g_val)
2)vfork保证子进程先运行 ,在调用了exec()或者exit()之后,父进程才可能被调度运行
pid_t id=vfork();
if(id<){
perror("vfork");
return ;
}
else if(id==){//child
//g_val=100;
printf("child:pid:%d ppid:%d\n",\
getpid(),getppid());
sleep(); //让子进程先等待3秒再调用exit
exit();
}
else{
printf("father:pid:%d,ppid:%d\n",\
getpid(),getppid());
}
结果是:子进程打印,等待3秒(调用了exit),父进程被调度