C逆向-变量是什么

本文详细阐述了编程中局部变量和全局变量的概念,强调了它们的作用域(函数作用域和块级作用域)、生命周期以及全局变量不受作用域限制的特点。通过内存地址顺序,展示了如何通过反汇编分析源代码。
摘要由CSDN通过智能技术生成

概念

  • 变量的作用域: 变量的作用域指变量在源码中可以被访问的范围
  • 变量的生命周期: 变量的生命周期指变量所在的内存从分配到释放的时间

局部变量

  • 生命周期
    • 局部变量的生命周期局限在函数作用域内,若超出作用域,则由栈平衡操作来释放局部变量的空间
  • 作用域
    1. 函数内部的局部变量: 在函数内部声明的变量通常只能在函数内部访问。这意味着在函数外部无法直接访问函数内的局部变量。

    2. "{ }" 划分的块作用域: 由花括号 { } 定义的范围,成为块级作用域。在这种情况下,其内部的局部变量生命周期和函数作用域一致,但是编译器会在编译前检查语法,限制块外代码的访问

      int Fun1()
      {
      	int a = 0; 					//定义局部变量
      
      	if (a == 1)
      	{
      								//花括号定义的范围,成为了块级作用域
      
      		int b = 10; 			//定义一个局部变量,但是只能在"{}"内使用,这个是由编译器限制的
      	
      		a = 200;  				//这里调用的是花括号外的那个变量a
      
      		int a = 10; 			//定义一个新的变量,他只可以在"{}"内调用
      
      		a = 100;				//这里调用的是在花括号内声明的变量a
      	}
      
      		printf("%d \n",a);		//这里调用的是函数初始定义的那个变量a,在"if"语句内,定义了 a = 200; 所以调试出来的是200
      
      }
      
      

全局变量

  • 生命周期
    • 全局变量的生命周期起始于所在执行文件被操作系统加载后.程序结束运行并退出后,全局变量将被销毁.因此,全局变量可以再程序中的任何位置使用
  • 作用域

    全局变量属于进程作用域,也就是说,在整个进程中都能够访问这个全局变量

  • 地址顺序

    全局变量在内存中的地址顺序是先定义的变量在低地址,后定义的变量在高地址.有此特性即可根据反汇编代码中全局变量的所在地址,还原出高级代码中全局变量定义的先后顺序,更进一步接近源码.

具有初始值的全局变量,其值在链接时被写入创建的PE文件中,当用户执行该文件时,操作系统先分析这个PE中的数据,将各节中的数据填入对应的虚拟内存地址中.这时全局变量就已经存在了,PE的分析和加载工作完成后,才开始执行入口点的代码.因此全局变量不受作用域的影响,在程序中的任何位置都可以被访问和使用.

  • 11
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值