zoukankan      html  css  js  c++  java
  • 2017-2018-1 20155227 《信息安全系统设计基础》第五周学习总结

    2017-2018-1 20155227 《信息安全系统设计基础》第五周学习总结

    教材学习内容总结

    第三章

    程序编码

    • ISA

      指令集体系结构(ISA)定义了处理器状态指令的格式,以及每条指令对状态的影响。

    • 汇编命令与反汇编命令

      gcc -S xxx.c -o xxx.s 获得汇编代码,用gcc -c code.c产生目标文件code.o(二进制文件,无法直接查看),用objdump -d xxx.o反汇编可以查看目标代码文件内容。函数前两行汇编代码pushl %ebp,movl %esp,%ebp和后两行代码popl %ebp,ret所有函数都有,建立函数调用帧。

    数据格式

    • 不同数据的汇编代码后缀

    访问信息

    • 操作数的三种类型
    立即数,即常数值
    寄存器,表示某个寄存器的内容
    存储器,根据计算出来的地址(有效地址)访问某个存储器位置。 
    
    • 有效地址的计算方式 Imm(Eb,Ei,s) = Imm + R[Eb] + R[Ei]*s

    • MOV

      MOV相当于C语言的赋值“=”,不能从内存地址直接MOV到另一个内存地址,要用寄存器中转一下。

      MOV类中的指令将源操作数的值复制到目的操作数中,源操作数指定的值是一个立即数,存储在寄存器或存储器中,目的操作数指定一个位置,要么是一个寄存器,要么是一个存储器地址。

    • 局部变量

    局部变量通常是保存在寄存器中。因为,寄存器访问比存储器访问要快得多。

    算术和逻辑操作

    • 一元和二元操作
      一元操作:只有一个操作数,既是源又是目的,可以是一个寄存器,或者存储器位置。

      二元操作:第一个操作数可以是立即数、寄存器或者存储器位置;第二个操作数既是源也是又是目的,可以是寄存器或者存储器位置,但是不能同时是存储器位置。

      操作的顺序:第二个操作数 操作符 第一个操作数

    控制

    • 条件码

      CF:进位标志
      
      ZF:零标志
      
      SF:符号标志
      
      OF:溢出标志
      
    • 循环(while, for)

      C语言do-while循环:

         do
        body-statement
        while(test-expr);
    
     汇编实现形式:
    
         loop:
        body-statement
        t = test-expr;
        if(t)
            goto loop;
    

    过程

    • IA32
      IA32利用程序栈来支持过程调用(包括将数据和控制)。为单个过程分配的那部分栈做栈帧。最底端(地址最大)%ebp为帧指针;最顶端(地址最小)%esp为栈指针。

    • call指令的效果是将返回地址入栈,并跳转到被调用过程的起始处。返回地址是在程序中紧跟在call后面的那条指令的地址。目标是指明被调用过程起始的指令地址。

    • ret指令从栈中弹出地址,并跳转到这个位置。栈指针要指向前面call指令存储返回地址的位置

    异质的数据结构

    • C语言的struct声明创建一个数据类型,将可能不同类型的对象聚合到一个对象中。
    • 结构的所有组成部分都存放在一段连续区域内,结构的指针就是结构第一个字节的地址。

    数据对齐

    • 对于大多数x86-64指令来说,保持数据对齐能够提高效率,但是它不会影响程序的行为。

    教材学习中的问题和解决过程

    代码调试中的问题和解决过程

    • 问题1:

      在64位机器上产生32位汇编代码时出现以下问题:

    解决方法是在终端输入如下命令:sudo apt-get install libc6-dev-i386,安装一个库。

    但又出现以下问题:

         E: 无法获得锁 /var/lib/dpkg/lock - open (11: 资源暂时不可用)
         E: 无法锁定管理目录(/var/lib/dpkg/),是否有其他进程正占用它?
    

    解决方法如下:

    1.终端输入 ps -aux ,列出进程。找到含有apt‘-get的进程,直接sudo kill PID。解决。

    2.强制解锁,命令:
    sudo rm/var/cache/apt/archives/lock
    sudo rm /var/lib/dpkg/lock

    代码托管

    (statistics.sh脚本的运行结果截图)

    上周考试错题总结

    • 错题1

    针对以上代码:gcc -c *.c 可以得到m.o,swap.o两个模块,哪些符号会出现在swap.o模块的.symtab条目中()

    A  . buf
    
    
    B  . temp
    
    
    C  . swap
    
    
    D  . buffp0
    

    正确答案: A C D

    理解:temp是局部变量,不出现在符号表中。

    • 错题2

    dll,so文件的链接是运行在()

    A  . 编译时
    
    
    B  . 加载时
    
    
    C  . 运行时
    
    
    D  . 链接时
    

    正确答案: C

    • ...

    结对及互评

    点评模板:

    • 博客中值得学习的或问题:
      • xxx
      • xxx
      • ...
    • 代码中值得学习的或问题:
      • xxx
      • xxx
      • ...
    • 其他

    本周结对学习情况

    -[20155318](http://www.cnblogs.com/lxy1997/)
    - 结对照片
    - 结对学习内容
        - 教材第三章内容
        - XXXX
        - ...
    

    其他(感悟、思考等,可选)

    本周学习的内容很多,知识点有的是上学期汇编学过的,但都有所遗忘,所以学起来还是有点吃力。

    学习进度条

    代码行数(新增/累积) 博客量(新增/累积) 学习时间(新增/累积) 重要成长
    目标 5000行 30篇 400小时
    第一周 133/133 1/1 8/8
    第三周 159/292 1/3 10/18
    第五周 121/413 1/5 10/28

    尝试一下记录「计划学习时间」和「实际学习时间」,到期末看看能不能改进自己的计划能力。这个工作学习中很重要,也很有用。
    耗时估计的公式
    :Y=X+X/N ,Y=X-X/N,训练次数多了,X、Y就接近了。

    参考:软件工程软件的估计为什么这么难软件工程 估计方法

    • 计划学习时间:15小时

    • 实际学习时间:10小时

    • 改进情况:

    (有空多看看现代软件工程 课件
    软件工程师能力自我评价表
    )

    参考资料

  • 相关阅读:
    js将单个反斜杠转化为斜杠的问题
    HTML提供的6种空格
    JavaScript 内存管理
    JavaScript:4个常见的内存泄露
    正则多种匹配描述
    css3图片展示方式
    动态规划篇一:初见动态规划
    小球下落(Dropping Balls, Uva 679)
    破损的键盘(悲剧文本)(Broken Keyboard(a.k.a. Beiju Text),Uva 11988)
    铁轨(rails, ACM/ICPC CERC 1997,Uva 514)
  • 原文地址:https://www.cnblogs.com/guyanlin/p/7709615.html
Copyright © 2011-2022 走看看