c++中变量的Borland地址
C++ Borland address of the variable
int main(int argc, char* argv[])
{
int *pInt;
int iParam = 423425;
pInt = &iParam;
std::cout<<&pInt<<std::endl;
system("pause");
return 0;
}
为什么我得到的地址像1250008,而不是像0x00000 ?
返回pInt
在虚拟内存中的地址。
它可以是任何地址。编译器可以自由地将指针放置在分配给进程的地址空间中的任何地址上。
如果你想获得hex
而不是十进制的地址,你需要像这样使用I/O操纵符:
std::cout << hex << &pInt << std::endl;
如果执行printf("%x", iParam)语句,存储在iParam中的值被转换为十六进制并打印,但它不会以0X开始。同样的情况也适用于打印地址的情况。不以0X开头
相关文章:
- 将数组的地址分配给变量并删除
- 空基优化子对象的地址
- C++ 指针的内存地址和指向数组的内存地址如何相同?
- 在C++中打印指向不同基元数据类型的指针的内存地址
- 如何在c++程序中找到函数的地址
- 向量元素的引用地址与它所指向的向量元素的地址不同.为什么
- 被解释为低级别const的const对象的地址
- 将地址分配给本地指针后,公共对象的变量将消失
- 为什么我在leetcode上收到AddressSanitizer:地址0x602000000058上的堆缓冲区溢出错误
- 内联程序集printf将整数解释为地址
- 为什么指针不写入类的地址?
- 如何在C++中获取该对象的类声明中对象的地址?
- 通过按地址访问变量
- 当一个新对象被分配到它的地址时,对象是否必须被销毁
- 函数名是c中该函数的第一条指令的地址吗
- Visual Studio(或任何其他工具)能否将地址解释为调用堆栈(boost上下文)的开头
- ReadProcessMemory() 不适用于像 0x2840C6C68D8 这样的长地址
- CUDA:统一内存和指针地址的更改
- c++中变量的Borland地址
- 虚拟内存地址空间不足(Borland C++Builder 6程序)