·C语言中变量的声明包括两个部分:类型,声明符
·对于简单类型,声明并不会对代码产生多大的阅读障碍,而对于复杂类型的识别,能够采用右左右左法进行判断linux
·指针数组:即用于存储指针的数组,也就是数组元素都是指针int a[10]
·数组指针:即指向驻足的指针,指针指向一个类型和元素个数都固定的数组int (a)[10]
·指针函数:即返回值是指针类型的函数int fuk()
·函数指针:即指向函数的指针,函数名就是函数指针int (fuk1)()
对于简单类型,声明并不会对代码产生多大的阅读障碍,而对于复杂类型的识别,能够采用右左右左法进行判断git
从变量名开始,先右再左地,交替地一个一个向外看,在纸上写下:“变量是”
若向右遇到左圆括号,在纸上写下:“函数,参数是”,并用一样的方法处理括号中每个参数——在纸上写下:“返回”
若向右遇到方括号,在纸上写下:“数组,长度为{方括号的内容},元素类型为”
若向右遇到右圆括号,什么也不作
若向左遇到*,在纸上写下:“指针,指向”
若向左遇到任何类型,在纸上写下对应的类型名shell
·由用户产生,如:Ctrl+C产生SIGINT信号等,能够经过stty -a查看哪些按键能够产生信号
·由硬件产生,如:当前进程执行了除以0的指令
·由进程发送,如:可在shell进程下,使用命令 kill -信号标号 PID,向指定进程发送信号。
·由内核产生,如:闹钟超时产生SIGALRM信号。
SIG_IGN是忽略信号的处理程序,表示无返回值的函数指针,指针值为1
SIG_DFL是默认信号的处理程序,表示无返回值的函数指针,指针值为0
能够经过stty -a查看能够产生信号的按键组合:
数组
·signal:
·不知道信号被发送的缘由
·信号处理过程当中不能安全地阻塞其余信号
·sigaction:
·在信号处理程序被调用时,系统创建的新信号屏蔽字会自动包括正被递送的信号。所以保证了在处理一个给定的信号时,若是这种信号再次发生,那么它会被阻塞到对前一个信号的处理结束为止
·响应函数设置后就一直有效,不会重置安全
·信号是由操做系统来处理的,说明信号的处理在内核态。信号不必定会当即被处理,此时会储存在信号的信号表中。
·信号的三种处理方式:函数
·忽略 ·默认处理方式:操做系统设定的默认处理方式 ·自定义信号处理方式:可自定义信号处理函数
利用命令man -k signal进行检索相关函数:
学习
sigdemo1.c运行结果以下图所示:
操作系统
signal(SIGINT,f)演示了如何捕捉信号,这个程序捕捉了中断信号
void f(int signum)演示了如何定义信号处理函数.net
·sigdemo2.c运行结果以下图所示:
·经过grep命令查看SIG_IGN,表示无返回值的函数指针,指针值为1
·SIG_DFL是默认信号的处理程序
·经过grep命令查看SIG_DFL,表示无返回值的函数指针,指针值为0
·sigdemo3.c运行结果以下图所示:
将sigdemo2.c中的SIG_IGN改为SIG_DFL,运行sigdemo4.c:
SIG_IGN是忽略信号,也就是当键盘输入一个Ctrl+C中断指令时,程序会将其忽略,而改为SIG_DFL后,恢复成了默认的状态,输入中断指令后,天然程序也就中断了
代码行数统计:
代码行数(新增/累积) | 博客量(新增/累积) | 学习时间(新增/累积) | |
---|---|---|---|
目标 | 5000行 | 30篇 | 400小时 |
第零周 | 0/0 | 1/1 | 10/10 |
第一周 | 100/100 | 1/2 | 20/20 |
第二周 | 120/220 | 1/3 | 35/55 |
第三周 | 226/446 | 1/4 | 30/85 |
第五周 | 141/587 | 1/5 | 30/115 |
第六周 | 150/737 | 1/6 | 25/140 |
第七周 | 100/837 | 1/7 | 20/160 |
第八周 | 0/837 | 2/9 | 30/190 |
第九周 | 183/1020 | 2/11 | 20/210 |
第十周 | 521/1541 | 3/14 | 20/230 |
第十一周 | 426/1967 | 1/15 | 35/265 |
第十二周 | 41/2008 | 3/18 | 50/315 |