加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c – 为什么我必须将地址转换为整数以使其可分配?

发布时间:2020-12-16 10:13:26 所属栏目:百科 来源:网络整理
导读:指针在堆上或堆栈上存储地址.经过一番搜索,我试图了解什么是“地址”;我发现它只是一个映射内存区域的整数值. 我想知道:只要一个地址只是一个整数,为什么我不能将它分配给一个整数变量: #include iostreamusing std::cout;using std::endl;int main(){ int
指针在堆上或堆栈上存储地址.经过一番搜索,我试图了解什么是“地址”;我发现它只是一个映射内存区域的整数值.

>我想知道:只要一个地址只是一个整数,为什么我不能将它分配给一个整数变量:

#include <iostream>
using std::cout;
using std::endl;

int main()
{
    int  a    = 1024;
    int* ptrA = &a;

    cout << "ptrA: " << ptrA << endl;   //  0018FF44
    cout << "*ptrA: " << *ptrA << endl; //  1024
    cout << "&a: " << &a << endl;       //  0018FF44
    cout << "a: " << a << endl;         //  1024

//  int b = ptrA;      // why this is incorrect
    int b = (int)ptrA; // why I need this?

    cout << "b: " << std::hex << b << endl; //  18FF44

    // so b is identic to ptrA!

    std::cout << std::endl;
    return 0;
}

解决方法

主要原因有两个.

> int可能不够大,无法存储指针值.这是一个特定于实现的细节.在具有64位内存地址的64位平台上找到C实现仍然很常见,其中int仅为32位.>类型安全.编译器存在不同类型的原因之一是捕获明显的错误,例如在指向不同类的指针时使用指向一个类的指针.如果对于每个对象的所有指针都只是简单的整数,那么这些错误将被解读.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读