本人感觉小白一个,刚学完操作系统原理,可是进程和线程总是很难理解啊,从编程的角度来讲:这都是面向对象的东西,实际编程时感觉很难下手,从理论到实践真的是差别很大,感觉用先前的c语言的知识很难理解执行顺序。如下代码
#include
#include
int main(int argc, char ** argv )
{
int pid = fork();
if (pid < 0)
{
printf("error!");
}
else if( pid == 0 )
{
printf("This is the child process!");
}
else{
printf("This is the parent process! child process id = %d", pid);
}
return 0;
}
1 运行时为什么先输出This is the parent process! child process id = %d"后输出This is the child process!,从程序的执行角度真的很难理解啊。
2 应该说创建一个进程就是运行一个程序,比如vc下的createProcess()启动了一个程序,比如说可以启动记事本程序,而linux下的调用fork()是做了什么,比如上面的程序好像感觉是启动了一个线程(书上说线程是一个执行代码,有自己的入口函数地址)
3 创建进程是父进程的一个副本,它将获得父进程数据空间、堆、栈等资源的副本,但是不共享,操作系统为他开辟与父进程不同的地址空间,我能否理解为子进程重新运行上面的程序,或者说执行一次运行了两个程序。
我也有点头大了,暂时想到这些,真心请教!!!!
关于创建进程,到底是如何看待这个
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
1条回答 默认 最新
- linux_ssj 2017-08-31 02:11关注
问题1:其实这两句printf的输出顺序并不是一直固定的,有可能会先打印This is the child process!,这跟进程的优先级有关。
问题2:过程是这样的,父进程调用fork,通过一系列系统调用,会跑到 do_fork() 这个函数,在这个函数中,会创建一个父进程的副本,也就是子进程,
当子进程创建完成的时候,fork() 函数其实是还没有返回的(也就是还没有结束),所以子进程会从父进程在fork函数中创建子进程的代码之后继续运行,
从你的代码来看,就是子进程和父进程都会执行一遍你的if else 判断的流程代码,只不过 对于子进程它的 fork返回值pid是不一样的,因此流程判断走的路也就不一样。
问题3:通过问题2应该理解了吧可以看看是怎么调用到内核中去的
解决 无用评论 打赏 举报
悬赏问题
- ¥15 多电路系统共用电源的串扰问题
- ¥15 slam rangenet++配置
- ¥15 有没有研究水声通信方面的帮我改俩matlab代码
- ¥15 对于相关问题的求解与代码
- ¥15 ubuntu子系统密码忘记
- ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
- ¥15 保护模式-系统加载-段寄存器
- ¥15 电脑桌面设定一个区域禁止鼠标操作
- ¥15 求NPF226060磁芯的详细资料
- ¥15 使用R语言marginaleffects包进行边际效应图绘制