C Fork 函数
Fork 函数:
#include <unistd.h>
pid_t fork(void);
由fork 创建的新进程被称为子进程。fork 函数被调用两次,但是返回两次。两次返回的唯一区别是子进程的返回值是0,而父进程的返回值则是新子进程的ID。将子进程的ID 返回给父进程的理由是:一个进程可以有多个子进程,并且没有函数是一个进程获得其子进程的进程ID。fork 在子进程中返回0的理由是:一个进程只能有一个父进程,并且可以通过getppid 函数获得其父进程的ID。
子进程和父进程继续执行fork 调用后的指令。子进程是父进程的副本。例如:子进程获得父进程的数据空间、堆和栈的副本。注意这是子进程自己的副本,父、子进程并不共享这些存储空间部分。父、子进程共享正文段。(这里可以参见http://blog.csdn.net/lihe2008125/archive/2010/05/11/5580487.aspx)
例子程序:(仅供参考)
#include "apue.h"
int glob= 6;
char buf[] = "a write to stdout\n";
int main(void){
int var;
pid_t pid;
var = 88;
if(write(STDOUT_FILENO,buf,sizeof(buf)-1) != sizeof(buf)-1)
err_sys("fork error");
printf("before fork\n");
if((pid = fork()) <0 ){
err_sys("fork error");
} else if(pid == 0){
glob++;
var++;
} else {
sleep(2);
}
printf("pid = %d, glob = %d, var = %d\n", getpid(), glob, var);
exit(0);
}
一般来说,在fork 之后是父进程先执行还是子进程先执行是不确定的。这取决于内核的算法。如果要求父、子进程之间相互同步,则要求某种形式的进程通信。
来自:UNIX 环境高级编程 第2版
相关文档:
检查内核参数
正在检查 semmsl=250; 已发现 semmsl=250。 通过
正在检查 semmns=32000; 已发现 semmns=32000。 通过
正在检查 semopm=100; 已发现 semopm=32。 失败 <<<<
正在检查 semmni=128; 已发现 semmni=128。 通过
正在检查 shmmax=536870912; 已发现 shmmax=33554432。 失败 <<<< ......
9.2 共用体
C语言除了提供结构体这种可包含多种类型数据的构造类型外,还提供了一种从形式上看和结构体堪称“孪生兄弟”的构造类型——共用体(union)。
本节从共用体的概念入手,从共用体的概念、与结构体的异同、使用等方面进行详细的介绍。
9.2.1 什么是共用体
现实生活中,某些事 ......
#include <stdio.h>
int Count=0;
void move(char x,int n,char z){
printf(" %d. disk %d: %c => %c\n",++Count,n,x,z);
}//move
// 将塔座x上按直径由小到大且自上而下编号为1至n的n个圆盘按规则搬到塔座z上,y可用作辅助塔座
void Hanoi(int n,char x,char y,char z){
if (n==1) move(x,1,z ......
我从数据库动态读取2个父节点:
111
a
a1
b
b1
c
&n ......
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <fcntl.h>
#include <unistd.h>
#include <sys/stat.h>
#include <sys/socket.h>
#include <arpa/inet.h>
#include <sys/types.h>
#include <sys/wait.h>
#define QLEN 20
# ......