C++中常量与指针讲解

在C++学习使用过程中,每个人都不可避免地使用指针,而且都或多或少的接触过常量指针或指针常量,但是对这两个的概念还是很容易搞糊涂的,所以这篇文章主要给大家介绍了关于C++中常量与指针的相关资料,需要的朋友可以参考下

前言

和指针联用有佷微妙的地方,之前一直佷晕,现在来继续研究下。诸如以下:

int const;
const int;
const int* p;
int const* p;
int* const p;
const int* const p;

const 是一种处理符号常量的方法,以 const 声明的变量,一般首字母大写,声明之后无法被修改。相比于 define,const 会显式的指定类型。除定义符号外,一般可用于函数声明,表示函数不会修改任何值;用于参数,表示函数不会修改参数;甚至可以用于声明数组的长度。

解读

const默认作用于其左边的东西。左边没东西的情况下,作用于其右边的东西。1

const int* p,只有右边有东西,修饰的为 int,所以数值不能被修改。在与 * 结合,意思是*p不能被修改,其它的都可以。即不可通过该指针改变其指向的内容,但可改变指针本身所指向的地址。

int const* p,先作用于左侧的 int 为 int const,在叠加上右侧的 ,所以修饰的为 int p,所以,*p不能被修改,其它的都可以。即不可通过该指针改变其指向的内容,但可改变指针本身所指向的地址。也就是,和上面的是一样的。

int* const p,左边是 *,所以 const 作用于指针,指向一个 int 变量。即不可以修改 p,但可以修改 *p,即不可改变指向的地址。

const int* const p,对于第一个 const,左边没东西,修饰右边的 int,指向的值不能修改;对于第二个 const 修饰 ,指针不能修改。即不可改变指针本身所指向的地址,也不可通过指针改变其指向的内容。同 int const const p。

int const* const* p,第一个 const 修饰 int,第二个 const 修饰第一个 ,也就是,指向 const int const p 的指针,最后一个 * 没有被修饰,因此可以指向其它变量。int const* const* const 就不可以了。之后再出现此类情况,也可以慢慢分析满天飞的 const 和指针。

一些例子

为了更好的理解上述内容,这里来举一些例子。常见的一般有两种选择:

常指针指向一个变量,防止修改指针修改变量值

常指针指向一个常量

非常指针指向常量(错误)

先看第一种情况:解引用只是取出指向内存区域的值,因此指向内存区域的值是可以直接修改的,但不能通过指针修改。

int main (){
   int a{34};
   const int *p = &a;
   // *p 为 const,不能被修改
   // 错误
   // *p ++;
   // p 指向的不是常量,因此,可以修改 a
   a ++;
   std::cout return 0;
}

对于第二种情况:不能修改变量,也不能修改常量。

int main (){

   const int a{34};
   // *p 为 const,不能被修改,a 也不能被修改
   const int *p = &a;
   std::cout return 0;
}

对于第三种情况:修改指针来修改常量会显得佷荒谬,因此编译会直接报错:

int main (){
   const int a{34};
   // error: invalid conversion from 'const int*' to 'int*'
   int *p = &a;
   *p ++;
   std::cout return 0;
}

二级指针

之前说到,常指针可以指向变量,但是涉及二级指针后,情况又会发生逆转。

int main (){

   const int a{12};
   const int** p1;
   int* p2;

   // error: invalid conversion from 'int**' to 'const int**'
   p1 = &p2;
   *p1 = &a;

   *p2 = 10;

   return 0;
}

如果上述代码通过,那么完全可以通过 p2 指针修改常量。因此我们可以得到以下结论:

若数据类型本身不是指针,可以将 const 数据或非 const 数据的地址赋给指向 const 的指针,但指针可以修改,指向别的值。因此,const 修饰的数组不能传参给非常量指针。

如果数据类型是指针,非 const 数据的地址只能赋值给非 const 指针,如二级指针中,p1 = &p2 是错误的。

总结

到此这篇关于C++中常量与指针的文章就介绍到这了。

原创文章,作者:晴川运维,如若转载,请注明出处:https://baike.qcidc.com/15717.html

(0)
晴川运维晴川运维
上一篇 2025年10月19日
下一篇 2025年10月19日

相关推荐

  • 简单介绍一下存储虚拟化技术

    存储虚拟化技术其实不是一个新东西,在很早以前就有了存储虚拟化技术。技术发展到今天,在存储虚拟化技术之上又诞生了其他很多新的概念和技术。 数据在整个计算机系统是最重要的一部分,也是最…

    Linux系统 2025年9月24日
  • 详解TCP长连接和短连接

    HTTP的长连接和短连接本质上是TCP长连接和短连接。HTTP属于应用层协议,在传输层使用TCP协议,在网络层使用IP协议。IP协议主要解决网络路由和寻址问题,TCP协议主要解决如…

    Linux系统 2025年6月8日
  • Linux下使用Aria2提高下载速度

    Aria2 是一个多平台轻量级,支持 HTTP、FTP、BitTorrent 等多协议、多来源的命令行下载工具。Aria2 可以从多个来源、多个协议下载资源,最大的程度上利用了你的…

    Linux系统 2025年10月22日
  • 详解Android root原理

    0x00 关于root linux和类Unix系统的最初设计都是针对多用户的操作系统,对于用户权限的管理很非常严格的,而root用户(超级用户)就是整个系统的唯一管理员,拥有等同于…

    Linux系统 2025年10月4日
  • Github中开源安全工具大全

    本仓库收集的初衷是为向各类企业安全从业人员提供在企业信息安全防护体系建设过程中可以参考的开源安全扫描工具,以期望企业能够利用这些扫描器对自身业务进行自检,从而提高自身业务安全性。 …

    Linux系统 2025年6月8日
  • 服务之间调用RPC的原因是什么?

    RPC(Remote Procedure Call):远程过程调用,它是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的思想。 RPC 是一种技术思想而非一种规范…

    Linux系统 2025年7月6日
  • 详解Linux内核之脏页跟踪

    Linux内核由于存在page cache, 一般修改的文件数据并不会马上同步到磁盘,会缓存在内存的page cache中,我们把这种和磁盘数据不一致的页称为脏页,脏页会在合适的时…

    Linux系统 2025年7月10日
  • Linux内核模块参数具体方法

    内核模块是Linux操作系统中一个比较独特的机制,采用模块化技术可以使得系统内核保持最小化,同时确保了内核的可扩展性和可维护性,模块化设计允许我们在需要时才将模块加载至内核,实现动…

    Linux系统 2025年10月5日
  • Linux中清除APT缓存具体方法

    Linux中如何清除APT缓存?本篇文章重点为大家讲解一下Linux中清除APT缓存具体方法,有需要的小伙伴可以参考一下。 如何清除 APT 缓存?你只需使用这个 apt-get …

    Linux系统 2025年6月8日
  • Linux中与用户账号相关的重要文件

    完成用户管理的工作有许多种方法,但是每一种方法实际上都是对有关的系统文件进行修改。 与用户和用户组相关的信息都存放在一些系统文件中,这些文件包括/etc/passwd, /etc/…

    Linux系统 2025年6月9日

发表回复

登录后才能评论