不同类型变量的存储位置及相对效率

前言

如果说并行计算是常数级的效率优化,并不能改变所运行算法的时间复杂度,那么C++语言的相对效率就是在程序的众多细小的地方进行改善。可能每个微小的改变之会让程序快几个时钟周期。但是,如果这个操作的运行要以兆计次呢。

如果时光倒流三十年,这些操作大概是程序员的必修吧。

不同范围类型的变量,应在哪里存储

栈存储(Storage on the stack)

  1. 在函数中声明的局部变量和对象都使用栈存储。
  2. 栈是内存的一部分,对于函数返回地址、函数参数、局部变量,每次调用函数都会在内存中分配栈空间,当函数返回时释放该空间。
  3. 因为重复使用相同范围的地址,栈是用来存储数据效率最高的空间(如果没有很大的数组,这部分数据将在一级缓存中)。
  4. 所有变量和对象最好在使用它们的函数中声明。

全局或静态存储(Global or static storage)

  1. 任何函数之外声明的变量称为全局变量。
  2. 全局变量的优点是可以在程序启动之前将其初始化为所需的值。
  3. 全局变量的内存空间在整个程序执行过程中都被占用。
  4. 如果非必需,就不要声明全局变量(不同线程之间的通信需要全局变量是唯一无法避免的情况)。

寄存器存储(Register storage)

  1. 寄存器存储,存储的是在函数中声明的局部变量和对象(原因在第二条)。
  2. 所有优化编译器都会自动选择一个函数中最常用的变量存储在寄存器中。
  3. 同一个寄存器可以用于多个变量,只要他们的使用周期不重叠。。
  4. 寄存器的数量非常有限,64位系统,约有14个整数寄存器,16个浮点寄存器。

易变变量(volatile)

  1. volatile关键字可将一个变量声明为可被其它线程改变(我还没用过)。
  2. volatile关键字不具有原子性,即其可以被两个或两个以上变量同时改变。

线程本地存储(Thread-local storage)

  1. 大多数编译器可以使用关键字__thread或__declspec(thread)来实现静态变量和全局变量的线程本地存储。
  2. 即每一个线程,都具有变量的一个副本。
  3. 由于线程本地存储是通过在线程环境块中的指针进行访问,因此是低效的。
  4. 应尽量避免线程本地存储。

Far

  1. 在具有分段内存的系统中,可以通过Far关键字将变量存储在其它数据段中(开始自由起来…)。
  2. far关键字同样也是低效的。

动态内存分配

  1. 内存中可以通过堆(一种数据结构)来存储动态分配的变量。
  2. 动态内存分配由new和delete运算符或malloc和free函数完成,这些运算符和函数会消耗大量时间。
  3. 动态内存分配是低效的,且会使代码更复杂且容易出错。
  4. 动态内存分配在后面会继续详细讨论。

类中声明的变量

  1. 类中声明的变量安装他们在类声明中的顺序存储。
  2. 存储类型(堆、栈还是内存静态空间)由对象在哪里定义来决定。
  3. 将变量存储在类或结构中是一种很好的方法,可以确保在程序中的相同部分中使用的变量也存储在彼此附近。
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值