1.进程的创建
(1)函数
pid_t fork(void);
属性:系统调用函数
(2).fork函数
fork出错 返回-1,fork函数调用一次,返回两次。
fork之后,父子进程就是两个独立的进程,谁先运行,操作系统决定
(3)子进程与父进程
在原来的进程中返回新进程pid(不可能等于0),在新进程中返回0
新进程继承原来的数据,程序计数器:新进程从fork之后开始运行
子进程:新进程
父进程:原来的进程
int main()
{
pid_t n =fork();
assert(n != -1);
if(n == 0)
{
printf("hello: pid = %d,ppid = %d\n",getpid(),getppid());
//子进程pid,父进程ppid
else
{
printf("world: pid = %d , n ==%d\n",getpid(),n);
}
exit(0);
}
实例:
int main()
{
int i= 0;
for(;i<2;++i)//第二次循环,++i后,父子进程开始独立
{
if(fork() == 0)
{
printf("A\n");
}
else
{
printf("B\n");
}
exit(0);
}
//结果3B3A
过程:
2.地址映射
1.实地址模式:
cs(寄存器)<<4 + Ip = 物理地址
- cs<<4:基地址
- Ip:偏移量(逻辑地址)
2.保护地址模式
基地址 + 段大小+权限
- GDTR:全局段描述符表寄存器(0)
- LDTR:局部段描述符表寄存器(1)
- cs,ds,ss(寄存器)16位
分段地址映射:
线性地址:GDTR[DS>>3].BaseAddr(基地址) + IP(逻辑地址)
地址转换
注:未开启分页机制,线性地址就是物理地址。开启时,线性地址就是虚拟地址 ,多级映射(2级32位 ,3级36位,4级64位)
段选择子(每个段的起始地址必须是16的倍数)
操作系统默认占12项,剩余用户使用8180