UNIX
时间:
日历时间
--
自1970
年1
月1
日00:00:00
以来的国际标准时间(UTC).
进程时间【CPU
时间】
时钟时间--
进程运行时间的总量。
用户CPU
时间--
执行用户指令时间量。
系统CPU
时间--
执行内核所经历时间。
命令
--time
第三章至第七章:
原子操作--
任何一个要求多于1
个函数调用的操作都不能成为原子操作,因
为在两个函数调用之间,内核有可能会临时挂起该进程.
术语
——
不带缓存指的是每个r e a d
和w
r i t e
都调用内核中的一个系统调用。这些不带缓存的I / O
函数不是ANSI C
的组成部分,但是是P O S I X . 1
和X P G 3
的组成部分。
unix shell
对应三个文件描述符
:标准输入,输出,出错;
对一个进程会预定义这三个进程
:标准输入,输出,出错。
文件I/O
相关函数
: open, create, close, lseek, read, write
等等,
有
内核返回给进程一个文件描述符,然后对其进行I/O 操
作; 而标准I/O 库 返回的则是流,所有的操作也是针对
流进行的。
read
函数
--
网络上的缓冲机制可能会造成返回值小于所要求读的字节数;
选择所读取BUFFERSIZE 的大小为8192 的时候,系统时间是最小
的,以后再增加这个大小对系统时间无影响。
标准I/O
提供三种类型的缓存
:全缓存,行缓存,不带缓存。
术语刷新(flush
)说明标准I / O
缓存的写操作
。值得引起注意的是在UXIX
环境中,刷新有两种意思。在标准I / O
库方面,刷新意味着将缓存中的内容写到磁盘上(该缓存可以只是局部填写的),
在终端驱动程序方面(例如在第11
章中所述的 tcflush
函数),刷新表示丢弃已存在缓存中的数据。
典型的存储器布局:
高地址:命令行参数和环境变量
栈【向下增长】
堆【向上增长】
未初始化数据
初始化数据
底地址
正文[
可共享,如果只读,则fork
后的父子进程共享正文
段]
;#
正文段到底是指什么?
进程控制:
进程标识符
包括进程ID,
父进程ID,
实际用户ID,
有效用户ID,
实际组
ID, 有效组ID.
进程ID
进程ID
为0
是调度进程(
交换进程)--
是内核的一部分,属于系统进
程; 进程ID 为1 是init 进程,由内核调用。/etc/init 或/sbin/init. 属于用户进程,要以超级用户特权运行。进程ID 为1 是页精灵进程,此进程负责支持虚存系统的请页操作,与交换进程一样也属于内核进程。
fork
函数:
pid_t fork(void);
调用一次返回两次,子进程返回的是0
, 而父进程返回值则是新子进程的进程ID.
这样父进程就拥有了子进程的id,
而子进程可以通过getppid
函数来获取。这位父,子进程相互通信建立了条件。
fork, exec
常使用copy-on-write
技术。[fork-exec
称为 spawn]
10.6
节讨论如何使用信号来使父,子进程同步。
fork 两次避免僵尸进程:
http://blog.chinaunix.net/u3/93893/showart_1991136.html
父进程结束后,其子进程怎么办?
父进程结束后,内核会检查所有活动的进程,以判断他是否是正在终
止进程的子进程,如果是子进程的父进程会转为init 进程也称为
init
领养的进程。
子进程结束后,父进程在做相应检查时如何得到子进程的终止状态?
内核为每个终止进程的子进程保存一定量的信息,所以当终止进程的
父进程调用wait
或waitpid
时,可以得到信息。
僵死进程概念:
一个已经终止但是其父进程未对其进行善后处理(
如没有释放资源)
的进程。
init
进程领养的进程终止会成为僵尸进程嘛?
不会,因为init
设计成当子进程终止,init
就会调用wait
函数取
得其终止状态,这样就可以防止在系统中有很多僵尸进程。
wait
和waitpid
函数
当一个进程终止时,内核就会向其父进程发送SIGCHLD
信号。因为子
进程终止是个异步事件,系统对于该信号默认采用忽略方式,否则自
己可以定义一个信号处理函数。
区别:
1:
子进程终止前,wait
使其调用者阻塞,而waitpid
有一个选
择项,可使调用者不阻塞。
2:waitpid
并不等待第一个终止的子进程,它有若干个选择项,
可以控制它所等待的进程。
waitpid
的pid
参数解释与其值有关:
pid == -1
等待任一子进程。于是在这一功能方面waitpid
与wait
等效。
pid > 0
等待其进程I D
与p i d
相等的子进程。
pid == 0
等待其组I D
等于调用进程的组I D
的任一子进程。
pid < -1
等待其组I D
等于p i d
的绝对值的任一子进程。
waitpid
函数提供了 wait
函数没有提供的三个功能:
(1) waitpid
等待一个特定的进程(
而w a i t
则返回任一终止子进
程的状态)
。在讨论p o p e n
函数时会再说明这一功能。
(2) waitpid
提供了一个w a i t
的非阻塞版本。有时希望取得一个
子进程的状态,但不想阻塞。
(3) waitpid
支持作业控制(以W U N T R A C E D
选择项)。
竞态条件概念:
当多个进程都企图对共享数据进行某种处理,而最后的结果又取决于
进程运行的顺序时,则我们认为这发生了竞态条件
1411

被折叠的 条评论
为什么被折叠?



