c – 存储在寄存器中的变量的地址

前端之家收集整理的这篇文章主要介绍了c – 存储在寄存器中的变量的地址前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
如果我的代码中的某处,我使用变量的地址(例如传递给其他一些函数),编译器会自动选择将其存储在内存中? (与将其存储在寄存器中的可能性相反). @H_404_2@否则,如果我要求这样一个变量的地址(存储为寄存器),会发生什么情况?我知道我们不能将变量的地址显式设置为register(注册int c).

@H_404_2@编辑:

@H_404_2@例如,如果我做某事

int c = 1;
print("Address of c: %p",&c);
@H_404_2@那么这个变量不能存储在一个寄存器中,可以吗?编译器会自动将其设置为存储在内存中?否则(如果它只是存储在一个寄存器中),屏幕上显示的地址是什么?

解决方法

首先,C标准禁止使用已声明注册的变量的地址,就像在结构体中的位域一样. @H_404_2@对于非注册(“auto”)变量,简短的答案是肯定的.优化器的最简单的策略是立即溢出其地址被占用的变量.

@H_404_2@“溢出”只是从寄存器分配的文献中的一个术语,意思是“决定将其置于记忆而不是注册”.

@H_404_2@复杂的优化器可以进行别名分析,并且仍然在寄存器中保存一个值,尽管它的地址已被采用.无论何处可以证明生成的指针不可能用于更改值,这是可能的.

@H_404_2@另一个相关的优化是实时分割.这允许将变量存储在寄存器中用于存储有用值(其“活动范围”)的部分指令范围,并将其溢出到其他部分.在这种情况下,溢出的部分将对应于指针可能用于更改变量值的位置.例如:

x = 3;
... lots of computations involving x
if T {
  // SPILL HERE,so store register holding x to memory
  int *p = &x;
  ... lots of computations,perhaps using p to change x
  *p = 2;
  // DONE SPILL HERE,so reload register
  ... more code here not using p to change x.
}
else {
  ... lots of computations involving x.
}
@H_404_2@该代码的积极优化器可能为x分配堆栈位置,但将其加载到代码顶部的注册表中,将其保留在除了标记为SPILL的区域之外.该区域将被存储器的存储器和匹配的寄存器负载包围.

原文链接:https://www.f2er.com/c/111849.html

猜你在找的C&C++相关文章