免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2890 | 回复: 7
打印 上一主题 下一主题

[C++] 指针常量 问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-09-24 15:48 |只看该作者 |倒序浏览
本帖最后由 davidbreathe 于 2013-09-25 10:40 编辑

最近在看常量指针与指针常量,按照网上找到的网页做了下试验,发现有问题,但是不太明白,见如下代码:

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

int main(){
  char str1[] = {"hello"};
  char str2[] = {"word"};
  char * const pstr1 = str1;
  cout << pstr1
       << endl;
  *pstr1 = 'A';
  cout << pstr1
       << endl;
  return 0;
}

输出是
hello
Aello

验证了常量指针中,指针的地址不可修改,但是地址指向的内容可以修改

但是当代码如下时:
#include <iostream>
using std::cout;
using std::endl;

int main(){
  char * str1 = "hello";
  char * str2 = "word";

  char * const pstr1 = str1;
  cout << pstr1
       << endl;
  *pstr1 = 'A';
  cout << pstr1
       << endl;
  return 0;
}

在*pstr1='A'时就出现了core,

char str1[] 与char * str1,str1不都代表的是char数组的地址么?
为什么后一种代码就出错了?

新手,多谢指教!

论坛徽章:
1
摩羯座
日期:2013-12-19 10:04:07
2 [报告]
发表于 2013-09-25 09:29 |只看该作者
"hello"不能修改

论坛徽章:
0
3 [报告]
发表于 2013-09-25 09:45 |只看该作者
回复 2# lin5161678


    为什么不能修改?
我定义的是指针常量,即指针所指向的地址不能变化,但是地址存储的内容是可变的。
第一段代码也验证了这点,修改后的输出为Aello。

但是第二段在修改时就出现了core,编译没有问题,core是在运行时出现的。

两段代码的区别是,str1 和 str2的定义不同。所以想知道,char * str1 与char str1[]有什么不同。

上面是我的理解,不知道是否正确。

论坛徽章:
0
4 [报告]
发表于 2013-09-25 09:56 |只看该作者
char * str1 = "hello";
存储在静态存储区,不允许修改

论坛徽章:
12
巳蛇
日期:2013-09-16 15:32:242015年辞旧岁徽章
日期:2015-03-03 16:54:152015年亚洲杯之约旦
日期:2015-02-11 14:38:37双鱼座
日期:2015-01-05 11:05:47戌狗
日期:2014-12-08 09:41:18戌狗
日期:2014-08-15 09:29:29双子座
日期:2014-08-05 09:17:17卯兔
日期:2014-06-08 15:32:18巳蛇
日期:2014-01-27 08:47:08白羊座
日期:2013-11-28 21:04:15巨蟹座
日期:2013-11-13 21:58:012015年亚洲杯之科威特
日期:2015-04-17 16:51:51
5 [报告]
发表于 2013-09-25 10:16 |只看该作者
  1. 两段代码的区别是,str1 和 str2的定义不同。所以想知道,char * str1 与char str1[]有什么不同。
复制代码
char * str1    这样声明了一个指针,指针需要指向一块合法地址才能用;而char * str1 = "hello"就是让str1指向hello的起始地址,因为hello是字符串常量,不能修改,所以程序会core掉。

char str1[] = "hello" 这样声明了一个数组,数组的大小会自动计算。

论坛徽章:
17
处女座
日期:2013-08-27 09:59:352015亚冠之柏太阳神
日期:2015-07-30 10:16:402015亚冠之萨济拖拉机
日期:2015-07-29 18:58:182015年亚洲杯之巴勒斯坦
日期:2015-03-06 17:38:17摩羯座
日期:2014-12-11 21:31:34戌狗
日期:2014-07-20 20:57:32子鼠
日期:2014-05-15 16:25:21亥猪
日期:2014-02-11 17:32:05丑牛
日期:2014-01-20 15:45:51丑牛
日期:2013-10-22 11:12:56双子座
日期:2013-10-18 16:28:17白羊座
日期:2013-10-18 10:50:45
6 [报告]
发表于 2013-09-25 10:29 |只看该作者

论坛徽章:
0
7 [报告]
发表于 2013-09-25 10:47 |只看该作者
多谢各位不吝指教了,:)

我自己总结下:
出现core的原因,确实在char str1[]与char * str1二者的区别上

其中char str1[]是一个char数组,数组中的内容是可以修改的。
但是char * str1是一个字符串常量,指针指向了这个字符串常量的初始地址,因是常量,因此是不可以修改的。

对@myworkstation提供的两个链接,第二个链接的文字解释部分更清楚些,:)。明确表示了“C++明确了string literal是不可修改的

在此也多谢楼上各位的解答,多谢多谢!

论坛徽章:
1
摩羯座
日期:2013-12-19 10:04:07
8 [报告]
发表于 2013-09-25 10:49 |只看该作者
"hello"
是字符串字面量

"hello"[0] = 'A'
这个做法是未定义行为
结果不可靠
有的编译器 就让你通过了
有的编译器 就运行报错
各种可能

这里出问题的原因是 "hello"本身不允许修改
不管你是用 str指针 还是 p指针
进行修改 都一样 会奔溃
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP