关于const应用与const中的c++陷阱

目录

const在不同位置的作用

[int *const pt 的含义](#int *const pt 的含义)

[const int *pt 的含义:](#const int *pt 的含义:)

[int *const pt与const int *pt 区别](#int *const pt与const int *pt 区别)

[const int *pt(pt指向一个const int)](#const int *pt(pt指向一个const int))

[int *const pt](#int *const pt)

C++陷阱:多级指针的const匹配

[疑问:为什么在一级间接关系 非const指针可以赋值给const指针](#疑问:为什么在一级间接关系 非const指针可以赋值给const指针)


const在不同位置的作用

int *const pt 的含义

pt 是一个指向常量整数的指针

const 修饰的是 pt 本身,不是 pt 指向的数据

这意味着:pt 不能改变指向 (不能指向其他地址)但可以通过 pt 修改指向的数据

const int *pt 的含义:

pt 是一个指向常量整数的指针

const 修饰的是pt指向的数据

这意味着:通过 pt 不能修改 它指向的数据 但 pt 本身可以改变指向(指向其他地址)

int *const pt与const int *pt 区别

const int *pt(pt指向一个const int)

cpp 复制代码
#include <iostream>
int main()
{
    using namespace std;
    int age =20;
    int *pd =&age;
    const int *pt =pd;
    cout<<"pt的值"<<*pt<<endl;
    cout<<"age的地址"<<&age<<endl;
    cout<<"pt指向的地址"<<pt<<endl;
    age=19;//通过更改age的值
    cout<<"更改后pt的值"<<*pt<<endl;
    cout<<"更改后age的地址"<<&age<<endl;
    cout<<"更改后pt指向的地址"<<pt<<endl;
    int agge=18;//更改pt的地址
    pt =&agge;
    cout<<"更改地址后pt的值"<<*pt<<endl;
    cout<<"agge的地址"<<&agge<<endl;
    cout<<"更改地址后pt指向的地址"<<pt<<endl;
    return 0;
    
}

输出的结果如下

通过观察输出的结果可以发现 在const int* pt中 pt可以通过修改其指向的地址来更改数据 同时也可以借助更改开始指向age的值来更改数据

int *const pt

cpp 复制代码
#include <iostream>
int main()
{
    using namespace std;
    int age =20;
    int *pd =&age;
    int *const pt =pd;
    cout<<"pt的值"<<*pt<<endl;
    cout<<"age的地址"<<&age<<endl;
    cout<<"pt指向的地址"<<pt<<endl;
    age =21;
    cout<<"更改后pt的值"<<*pt<<endl;
    cout<<"更改后age的地址"<<&age<<endl;
    cout<<"更改后pt指向的地址"<<pt<<endl;
    /*
    pt =&agge;
    cout<<"更改地址后pt的值"<<*pt<<endl;
    cout<<"agge的地址"<<&agge<<endl;
    cout<<"更改地址后pt指向的地址"<<pt<<endl;
    */
    //注意/**/中的代码会报错
    return 0;
}

注意上述代码后面/**/中的代码会报错 其报错的原因即可以证明出在int *const pt中 const修饰是pt本身 故其不可以更改其指向的地址 上述代码通过其开始修改age(其开始指向的地址)从而更改其值

C++陷阱:多级指针的const匹配

cpp 复制代码
#include <iostream>
int main()
{
    using namespace std;
    const int **pp2;
    int *pl;
    const int n =13;
    pp2= &pl;
    *pp2=&n;
    *pl=10;
    cout<<**pp2;
    return 0;
}

上述代码输出结果:error: assigning to 'const int **' from incompatible type 'int **'

pp2= &pl;

^~~

1 error generated.

为什么上述代码会发生报错 其根本原因在于其犯了"非const指针赋值给const指针"

如果允许上述代码运行 观察下述

cpp 复制代码
const int **pp2;
int *pl;
const int n = 13;

pp2 = &pl;      // 如果允许这个
*pp2 = &n;      // 那么*pp2(即pl)现在指向const的n
*pl = 10;       // 通过非const指针pl修改了const变量n!违反const原则

pp2指向pl的地址(即pp2存储的是pl变量的地址)

->通过pp2解引用访问pl,让pl指向n的地址

->通过pl解引用访问n,将n的值修改为10

**其行为违反const的原则:**const指针承诺不修改所指向的对象,如果我们允许将非const指针(即可以修改所指向对象的指针)赋值给const指针,那么通过这个const指针我们虽然不会修改对象,但是原来的非const指针仍然可以修改对象,这实际上破坏了const指针所做的承诺(即指向的对象不会被修改)。

疑问:为什么在一级间接关系 非const指针可以赋值给const指针

int* p1;

const int* p2 = p1;

观察上述发现 其实其是通过p2来进行访问p1的

其根本原因是因为其权限不同

源指针 (int*):具有读写权限

目标指针 (const int*):只有读权限

即p1将地址传给p2 由于const int*的限制 其只有读权限 无法对地址的值进行修改

感谢阅读

相关推荐
coderxiaohan2 小时前
【C++】多态
开发语言·c++
gfdhy2 小时前
【c++】哈希算法深度解析:实现、核心作用与工业级应用
c语言·开发语言·c++·算法·密码学·哈希算法·哈希
ceclar1233 小时前
C++范围操作(2)
开发语言·c++
一个不知名程序员www4 小时前
算法学习入门---vector(C++)
c++·算法
明洞日记4 小时前
【数据结构手册002】动态数组vector - 连续内存的艺术与科学
开发语言·数据结构·c++
福尔摩斯张4 小时前
《C 语言指针从入门到精通:全面笔记 + 实战习题深度解析》(超详细)
linux·运维·服务器·c语言·开发语言·c++·算法
Dream it possible!5 小时前
LeetCode 面试经典 150_二叉搜索树_二叉搜索树的最小绝对差(85_530_C++_简单)
c++·leetcode·面试
麦烤楽鸡翅6 小时前
简单迭代法求单根的近似值
java·c++·python·数据分析·c·数值分析
sulikey8 小时前
C++ 四十年:一段跨越时代的语言旅程
c++·c++40周年