zoukankan      html  css  js  c++  java
  • 20145314郑凯杰《信息安全系统设计基础》第12周学习总结

    20145314郑凯杰《信息安全系统设计基础》第12周学习总结

    明确教材学习目标

    本周的任务是:

    1. 分析前三周的代码
    2. 完成第五周余下的任务:GDB调试汇编代码并分析
    3. 完成第十二周同学们问题的总结
    4. 完成视频学习
    5. 完成课上老师所授内容的整理

    分析前三周的代码

    http://www.cnblogs.com/5314zkj/p/6052730.html

    http://www.cnblogs.com/5314zkj/p/6059991.html

    http://www.cnblogs.com/5314zkj/p/6081872.html

    http://www.cnblogs.com/5314zkj/p/6107511.html

    GDB调试汇编代码并分析

    完成博客:

    http://www.cnblogs.com/5314zkj/p/6130521.html

    完成第十二周同学们问题的总结

    周一完成所有汇总,包括前三周问题的补缺补漏

    完成视频学习

    指针与声明

    C语言中变量的声明包括两个部分:

    • 类型
    • 声明符

    对于简单类型,声明并不会对代码产生多大的阅读障碍,而对于复杂类型的识别,可以采用右左右左法进行判断。

    信号处理

    信号是Linux系统响应某些条件而产生的一个事件,接收到该信号的进程会执行相应的操作。

    信号的产生

    • 由用户产生,如:Ctrl+C产生SIGINT信号等,可以通过stty -a查看哪些按键可以产生信号
    • 由硬件产生,如:当前进程执行了除以0的指令
    • 由进程发送,如:可在shell进程下,使用命令kill -信号标号 PID,向指定进程发送信号。
    • 由内核产生,如:闹钟超时产生SIGALRM信号。

    信号的处理

    信号是由操作系统来处理的,说明信号的处理在内核态。信号不一定会立即被处理,此时会储存在信号的信号表中。

    完成课上老师所授内容的整理

    指针数组、数组指针、指针函数、函数指针

    指针数组

    • 指针数组是数组。
    • 数组里的元素都是指针。
    • 例如:int *daytab[13]数组里有13个元素,每个元素都是一个整型指针。

    数组指针

    • 数组指针是指针。
    • 指针指向一个类型和元素都固定的数组。
    • 例如:int (*daytab)[13]指向一个数组,这个数组有13个元素,每个元素都是int类型。

    指针函数

    • 指针函数是函数。
    • 函数的返回类型是指针类型。
    • 例如:int *com()是指针函数,函数返回类型为整型指针。

    函数指针

    • 函数指针是指针。
    • 指针指向函数。
    • 函数名就是函数指针。
    • 例如:int (*com)()是函数指针,指向函数的参数为空,返回值类型为int。

    右左右左法

    具体方法:

    从变量名开始,先右再左地,交替地一个一个向外看,在纸上写下:“变量是”

    • 若向右遇到左圆括号,在纸上写下:“函数,参数是”,并用同样的方法处理括号中每一个参数——在纸上写下:“返回”
    • 若向右遇到方括号,在纸上写下:“数组,长度为{方括号的内容},元素类型为”
    • 若向右遇到右圆括号,什么也不做
    • 若向左遇到*,在纸上写下:“指针,指向”
    • 若向左遇到任何类型,在纸上写下对应的类型名

    举例说明:分析void ((*fp1)(int))[10]

    从fp1开始——fp1是

    • 向右,遇到右括号,什么也不做
    • 向左,遇到*——指针,指向
    • 向右,遇到左圆括号——函数,参数是int,返回
    • 向左,遇到*——指针,指向
    • 向右,遇到左方括号——数组,长度为10,元素类型为
    • 向左,遇到*——指针,指向
    • 向右,已经到声明结尾,什么也不做
    • 向左,遇到void——void

    结果是:fp1是 指针,指向 函数,参数是int,返回指针,指向数组,长度为10,元素类型为 指针,指向 void

    学习进度条

    代码行数(新增/累积) 博客量(新增/累积) 学习时间(新增/累积) 重要成长
    目标 5000行 30篇 400小时
    第八周 1300/1750 11/11 140/140
    第九周 1700/2000 13/13 160/160
    第十周 2000/2400 14/15 180/180
    第十一周 2500/2800 15/17 200/200

    | 第十二周 | 2500/3000 | 15/17 | 210/210 | |

    参考资料

  • 相关阅读:
    zookeeper部署
    Hadoop集群的构建和安装
    numpy ndarray求其最值的索引
    两数之和
    盛最多水的容器
    mysql 单表卡死
    Leetcode 258. Add Digits
    Matlab中添加路径与去除路径
    Leetcode 136 Single Number
    Leetcode 485. Max Consecutive Ones
  • 原文地址:https://www.cnblogs.com/5314zkj/p/6132306.html
Copyright © 2011-2022 走看看