zoukankan      html  css  js  c++  java
  • C语言与汇编衔接1

    研究实验二

     

    问题研究过程:

        发问:C语言中的变量究竟是什么,通过下面的程序进行C语言中的变量的学习

     

    图1  URL.EXE函数

     

    为了研究main函数的首地址,我首先自作聪明的用了一条_DX=main,这样一条语句,希望通过debug中的G命令执行完程序。通过DX的值得到main 的地址。但很不幸的是,最终DX的值为0000,并没有得到相应的程序执行结果。于是发问:

    为什么这个程序没有得到执行。那个G命令到底执行了什么?

    基于目前对汇编语言的理解,在这里一定要用main这个符号吗,可不可以换成别的符号?来标识所谓的主程序?

    于是打算通过单步执行来进一步仔细研究到底发生了什么:

    图2  单步执行结果

    然而出现了一堆无关的代码,此时并不清楚这些代码是什么,即CS:IP所指的位置并不知道有什么具体用处。研究了很长时间,但是还是没有想到用debug找出URL的main的地址。因此直接进入三

    在程序之前补一句代码,如图:

     

    图3  显示main的地址

    得到结果:

     

    图4  main 的偏移地址

    即得到了main的偏移地址

    此处继续发问:

    1. 书上所采用的单独写一个函数从原理上讲,并不合理,因为此处的main的地址非彼处的main的地址,没有道理认为两者就是同一个地址

    然而事实是:两者的main确实是同一个标志!!!

    用u cs:1fa查看,得到:

     

    图5  显示结果

    继续研究函数的本质:

     

    图6  子程序调用程序清单

     

    图7  子程序调用过程

       可以发现,当执行f();的时候确实是通过call的方式,并且还可以看出,从本质上讲,计算机并不区分什么是主程序,什么是子程序,从汇编代码可以看出,main函数任然是一个被调用的子程序,并没有任何的特殊地位!!

    通过研究发现:当把main换成其他标志时,进行编译连接的时候,会报错,于是推测,main是编译环境提供的一个标志,有其对应的固定地址。所以,在此回答上面体术的问题:main都是一样的,其表示的地址是一样的。

    总结感悟:

       通过实践得出的一个最重要的结论就是,c语言中所谓的函数其实本质就是子程序,即使是所谓的main()函数,也是如此。而且汇编语言中的寄存器就是C语言中的变量这一概念。不过这些概念在学习汇编和C语言的时候已经形成了,所以对于本次研究,感觉收获并不是很多。

  • 相关阅读:
    stack, deque 和 queue的对比
    Android 修改圆形progressBar颜色
    java.lang.OutOfMemoryError: Failed to allocate a 3110419 byte allocation with 741152 free bytes and
    Android GreenDAO 3.0 不修改版本号的情况下增加、删除表、添加字段
    Android监听安装卸载
    Android实现异步的几种方法
    Android GreenDao清空数据库的方法
    Android 6.0 动态权限申请
    Android无需权限显示悬浮窗
    Android 极光推送JPush---自定义提示音
  • 原文地址:https://www.cnblogs.com/shaonianpi/p/7995286.html
Copyright © 2011-2022 走看看