• Primer笔记——typedef指针类型别名时的const陷阱


    目录

    一.typedef int* pint 与 const pint

    二.typedef const int *pint 与 pint

    三.总结


    《C++ Primer》中指出,typedef与指针代指复合类型别名时,可能有意向不到的情况。

    下面我们以int为例:

    一.typedef int* pint 与 const pint

    此时typedef的类型是int的指针,即指针类型

    既然pint本身是指针类型,那么const pint修饰的就是指针类型,pint本身就是指向int的常量指针

    即const pint可以改成这种形式:

    const pint -> int* const

    而人们往往会错误的替换成const int*的形式,这就是误解了const的修饰对象。 

    以下面代码为例:

    1. typedef int* pint;
    2. int a = 1;
    3. int b = 2;
    4. const pint p = &a;
    5. //即int* const p = &a
    6. p = &b;//错误,常量指针不能修改指向
    7. *p = 3;//正确,指针指向int变量
    8. //注意:const pint p 与 pint const p等价

    那么怎样才能得到我们想要的const int*呢? 

    二.typedef const int *pint 与 pint

    虽然pint还是一个指针类型数据,但因为const int的存在,此时int是const类型的数据。

    pint此时指向const int,即指向常量int的指针。

    此时pint可变为如下形式:

    pint -> const int* 

     以下面代码为例:

    1. typedef const int* pint;
    2. int a = 1;
    3. int b = 2;
    4. pint p = &a;
    5. //即const int* p = &a;
    6. *p = 3;//错误,p指向常量
    7. p = &b;//正确,p本身是指针变量

    三.总结

    只要typedef中没有声明const,那么指针永远指向变量。

    只要类型别名在使用时有const修饰,那么指针永远是常量指针。

    即typedef中const决定指向对象属性,定义时const决定指针自身属性。

    说的官方一点就是typedef决定底层const,定义决定顶层const。 

    可以总结出如下表格:

    typedef定义替换形式含义
    typedef int* pint;pint p = &a;int* p指向变量的指针
    const pint p = &a;int* const p指向变量的常量指针
    typedef const int* pint;pint p = &a;const int* p指向常量的指针
    const pint p = &a;const int* const p指向常量的常量指针

    先解决问题再写代码——John Johnson


    如有错误,敬请斧正 

  • 相关阅读:
    (01)ORB-SLAM2源码无死角解析-(42) EPnP 源代码分析(3)→find_betas_approx(),gauss_newton()
    一文让你彻底搞懂js正则表达式
    Windows内核--源代码在哪里?(1)
    《痞子衡嵌入式半月刊》 第 65 期
    如何准备考pmp?
    AMS 、PMS服务探索
    struts2.x笔记
    RHCE8 资料整理(二)
    微服务之架构演变
    内存管理的概念
  • 原文地址:https://blog.csdn.net/weixin_61857742/article/details/127948434