关于常量指针和指向常量的指针在传参时的部分细节

1:当函数的形参为 char * 时,可以将 char* const(常量指针) 类型的对象作为实参传入:

因为传参的过程实际是将 char* const 复制给一个临时变量,函数中使用的是临时变量,因为char * const 是一个常量指针,即指针的指向不可改变(指针本身也占用内存,占4个字节的内存(根据系统位数不同大小不同),其内存储的是指向对象的地址,指向不可改变就是其内存储的地址不可改变)。但是在函数内部不管对指针做了什么操作,不管是改变临时变量的指向也好,还是指向地址的数据也好,都是对于临时变量的操作,跟原指针的指向不能改变的限定没有冲突,但是原指针指向地址的数据可能会被改变(后面会说到引用和指针的区别)

2:当函数的形参为 char * 时,不能将 const char * (指向常量的指针) 类型的对象作为实参传入:

因为 const char * 是指向常量的指针,意味着该指针的指向可以改变,但是指向的地址块的数据不可改变,而如果经由char * 传入函数的话,是有可能改变指向地址块的数据的,这与指向常量的指针的限定符冲突! 可以结合上一条思考,总结就是不与限定符冲突就是可以的,反之则不行。(可能有人会问,函数中不是临时变量吗?这与上一条略有不同,虽然是临时变量,但是其内存储的地址是跟原指针一样的,对临时变量做的操作对原指针没有影响,就像你传入了一个整型变量进函数,不管你函数里面做了什么操作,函数外面的整型变量是没有任何改变的,虽然对原指针没有影响,但是却真真切切的改变了指向的地址块里的数据,所以与本条指针的限定符冲突!)

3:当函数的形参为 char *& 时,不能将 char * const (常量指针) 类型的对象作为实参传入

如第一条所示, char * const 是一个不可更改指向的常量指针,而这里的形参是一个引用指针,引用就相当于给某个对象起了一个别名,就是对于引用变量的操作就是对原变量的操作,这里没有临时变量。所以如果作为参数传入了函数,是有可能改变指针的指向的,这与限定符冲突。

4:当函数的形参为 char *& 时,不能将 const char * 类型的对象作为实参传入

同理,很容易能知道将其作为参数传入也是与限定符冲突的!

当然如果形参也有与传入实参同样的限定符,那么以上四条则都是可以传入的,前提是有跟传入实参一样的限定符!

最后,可能对于 常量指针 还是 指向常量的指针有点难区分,可以从右向左阅读,例如:

char * const p; p是一个对象,const p说明这个对象是一个常量,是不可变的 , * 则说明这个对象是一个指针,所以这个对象是一个不可变的指针。即常量指针,常量指针能区分了,那指向常量的指针也就能区分了(其实不用可以去记名字,只要能理解含义,名字能不能记住也无所谓)

错误在所难免,烦请指正!

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值