- Mastering Linux Kernel Development
- Raghu Bharadwaj
- 242字
- 2021-07-08 09:47:18
fork()
Fork() is one of the core "Unix thread APIs" available across *nix systems since the inception of legacy Unix releases. Aptly named, it forks a new process from a running process. When fork() succeeds, the new process is created (referred to as child) by duplicating the caller's address space and task structure. On return from fork(), both caller (parent) and new process (child) resume executing instructions from the same code segment which was duplicated under copy-on-write. Fork() is perhaps the only API that enters kernel mode in the context of caller process, and on success returns to user mode in the context of both caller and child (new process).
Most resource entries of the parent's task structure such as memory descriptor, file descriptor table, signal descriptors, and scheduling attributes are inherited by the child, except for a few attributes such as memory locks, pending signals, active timers, and file record locks (for the full list of exceptions, refer to the fork(2) man page). A child process is assigned a unique pid and will refer to its parent's pid through the ppid field of its task structure; the child’s resource utilization and processor usage entries are reset to zero.
The parent process updates itself about the child’s state using the wait() system call and normally waits for the termination of the child process. Failing to call wait(), the child may terminate and be pushed into a zombie state.
- Clojure Programming Cookbook
- Monkey Game Development:Beginner's Guide
- Visual FoxPro程序設計教程(第3版)
- Learning Selenium Testing Tools with Python
- Python網絡爬蟲從入門到實踐(第2版)
- RTC程序設計:實時音視頻權威指南
- 深入淺出Windows API程序設計:編程基礎篇
- Linux網絡程序設計:基于龍芯平臺
- Cassandra Data Modeling and Analysis
- Data Analysis with Stata
- Learning jQuery(Fourth Edition)
- UX Design for Mobile
- HTML5移動前端開發基礎與實戰(微課版)
- Learning Cocos2d-JS Game Development
- Java程序設計教程