虚拟地址与物理地址的映射关系(借助页表)
由图中的映射关系我们可以发现,虚拟地址与物理地址并不是一一对应的,这样也就会出现一种问题,一个变量地址相同内容不同,其实是虚拟地址相同,所对应的物理地址不同的原因
那么是谁管理着虚拟地址空间呢?pcb中有mm_strct管理虚拟地址空间
linux中错误提示
linux中绝大多数函数出错返回值都是-1,函数出错后将错误编号放入errno全局变量中。
char*strerror(error)通过错误编号返回对应错误的描述信息,只有错误时才描述有效,我们可以用printf(“%s”,strerror(errno))打印出这个错误信息
errno头文件<errno.h> strerror头文件<string.h>
当然我们现在也可以使用简单的报错信息perror()
fork与vfork
fork代码:
1 #include<stdio.h>
2 #include<stdlib.h>
3 int main()
4 {
5 pid_t id=fork();
6 if(id<0)
7 {
8 perror("fork");
9 return 0;
10 }
11 else if(id==0)
12 {
13 printf("this is child :%d\n",getpid());
14 }
15 else
16 {
17 printf("this is parent:%d\n",getppid());
18 }
19 return 0;
20 }
vfork代码:
1 #include<stdio.h>
2 #include<stdlib.h>
3 int main()
4 {
5 pid_t id=vfork();
6 if(id<0)
7 {
8 printf("vfork");
9 return -1;
10 }
11 else if(id==0)
12 {
13 printf("this is child :%d\n",getpid());
14 }
15 else
16 {
17 printf("this is parent :%d",getppid());
18 }
19 exit(1);
20 }
~
大家可能乍眼一看,哎哟,没什么区别吗,只不过就是把fork函数替换成了vfork,其实两者的用法很相似,但还是存在一定的差别,我们先执行一下:
fork:
vfork:
fork与vfork的区别:
1.fork()函数会转入内核执行,父子进程交替执行,而vfork() 子进程先运行,子进程结束父进程运行
2.fork()是子进程拷贝父进程的数据段、代码段,vfork()子进程与父进程共享数据段
3.fork写时拷贝,vfork不进行拷贝动作,所以vfork性能比fork更好,但退出时一定要用exit
如果我们皮一下不用exit会造成什么结果呢??
所以千万要记得!!!!