文章仅代表作者想法, 其中细节希望读者探究 。
思考
在操作系统中, 一个程序的运行,不用程序用进程来替代可能更好 , 进程的运行并不可能是自发, 必然由另一个进程引发,当执行一个程序的时候,通过系统调用execve来执行程序程序。那程序流的切换操作系统的内核做了什么?
kernel装载程序
无论是在终端启动或者双击应用运行代码在本质上都是使用do_execve系统调用,通过系统调用进程从用户态转换到内核态,在内核态中检查文件类型,是否超过最大进程数 , kernel是否支持文件格式, 设置好uid , ugid 后将读取二进制文件, 载入目标文件格式 , 修改当前用户态进程ip , sp , cs , ss 等寄存器后痛过force_iret 返回用户态执行目标文件
https://0xax.gitbooks.io/linux-insides/content/SysCall/linux-syscall-4.html