Chinaunix首页 | 论坛 | 博客
  • 博客访问: 32758
  • 博文数量: 9
  • 博客积分: 10
  • 博客等级: 民兵
  • 技术积分: 100
  • 用 户 组: 普通用户
  • 注册时间: 2012-03-27 11:03
文章分类

全部博文(9)

文章存档

2015年(9)

我的朋友

分类: LINUX

2015-11-05 20:33:58

1.9信号
    当发生某种事件时通知进程,并由进程做相应处理的信息

    进程处理信号的三种方法:
        忽略该信号
        按系统默认方式处理
        提供一个函数,信号发生时调用该函数

    键盘上有两个产生信号的方法:中断键:ctrl+c 退出键 ctrl+\

点击(此处)折叠或打开

  1. [root@node3 apue.2e]# cat fig1.10
  2. #include "apue.h"
  3. #include <sys/wait.h>

  4. static void sig_int(int); /* our signal-catching function */

  5. int
  6. main(void)
  7. {
  8.         char buf[MAXLINE]; /* from apue.h */
  9.         pid_t pid;
  10.         int status;

  11.         if (signal(SIGINT, sig_int) == SIG_ERR) #当发生中断信号时,调用sig_int函数
  12.                 err_sys("signal error");

  13.         printf("%% "); /* print prompt (printf requires %% to print %) */
  14.         while (fgets(buf, MAXLINE, stdin) != NULL) {
  15.                 if (buf[strlen(buf) - 1] == '\n')
  16.                         buf[strlen(buf) - 1] = 0; /* replace newline with null */

  17.                 if ((pid = fork()) < 0) {
  18.                         err_sys("fork error");
  19.                 } else if (pid == 0) { /* child */
  20.                         execlp(buf, buf, (char *)0);
  21.                         err_ret("couldn't execute: %s", buf);
  22.                         exit(127);
  23.                 }

  24.                 /* parent */
  25.                 if ((pid = waitpid(pid, &status, 0)) < 0)
  26.                         err_sys("waitpid error");
  27.                 printf("%% ");
  28.         }
  29.         exit(0);
  30. }

  31. void
  32. sig_int(int signo)
  33. {
  34.         printf("interrupt\n%% ");
  35. }
  36. [root@node3 apue.2e]# mv fig1.10 fig1.10.c
  37. [root@node3 apue.2e]# gcc fig1.10.c
  38. [root@node3 apue.2e]# ./a.out
  39. % interrupt
  40. % [root@node3 apue.2e]#
1.10时间值
    日历时间:自1970年1月1日00:00:00以来(国际标准时间)所经过的秒数累计值
    进程时间:又称为CPU时间,用户CPU时间+系统CPU时间=CPU时间
    用户CPU时间:是执行用户指令所用的时间
    系统CPU时间:内核为执行该进程,内核程序所经历的时间
    时钟时间:从该进程刚刚开始执行到该进程执行完毕的总时间。

    一般情况下,时钟时间>用户CPU时间+系统CPU时间

点击(此处)折叠或打开

  1. [root@node3 apue.2e]# time -p find /usr/include/ -name "*.h" -print
  2. ...
  3. real 7.27
  4. user 0.05
  5. sys 0.31

1.11系统调用和库函数


1.12小结

阅读(959) | 评论(0) | 转发(0) |
0

上一篇:Unix环境高级编程一

下一篇:没有了

给主人留下些什么吧!~~