#include <cstdio>
int main(int argc, char const *argv[])
{
int aa[10]={1,2,3,4};
int * a = aa;
for (int i = 0; i < 4; ++i)
{
unsigned int b = (int)&a[i];
printf("%p : %x\n",&a[i],b );
}
}
b保存的是a[i]的地址,但是正常编译会出错,
a.cpp:6:24: warning: cast from ‘int*’ to ‘int’ loses precision [-fpermissive]
unsigned int b = (int)a;
^
通过-fpermissive
参数之后,error变成warning可以正常运行,某次的结果如下:
0x7ffeac7db3d0 : ac7db3d0
0x7ffeac7db3d4 : ac7db3d4
0x7ffeac7db3d8 : ac7db3d8
0x7ffeac7db3dc : ac7db3dc
为什么输出会不一样?
另外,如何正常保存变量的地址到一个数组,以便后续对这个“地址数字”进行操作?(就是后面想对0x7ffeac7db3d0这样的数据进行操作,而不是看成一个地址了)
質問の対象は 64 ビット マシンですか?コンパイルエラーを見ると、変換がエラーの原因となっているようです。 64ビット、ポインタは8バイト、intは4バイトです。これをlong longに変更してコンパイルしたのがこの問題のようです。
リーリーアドレスをlong long配列に保存し、整数として扱うと、処理できるようになります。
エラーメッセージを表示
リーリーは、
int*
をint
に変換すると精度が失われることを意味します。int*
型とint
型が占有するメモリ サイズが異なるためです。-fpermissive
パラメータを使用すると、トレラント モードが強制され、精度が失われる可能性があります。通常、マシンはリトルエンディアン (ここにあるもの) なので、整数を変換するときに、それ以上のビットを格納できない場合は、下位ビット、つまり仮数部のみを格納できます。
メモリ アドレスの保存には
int
などの型を使用しないで、対応するポインター型またはvoid*
型を使用してください。linux
の下にあるはずです。intptr_t
を使用することをお勧めします。