6

好的,我知道这是无效的

 char char_A = 'A';
    const char * myPtr = &char_A;
    *myPtr = 'J'; // error - can't change value of *myP

[因为我们声明了一个指向常量字符的指针]

为什么这是有效的?

 const char  *linuxDistro[6]={ "Debian", "Ubuntu", "OpenSuse", "Fedora", "Linux Mint", "Mandriva"};

for ( int i=0; i < 6; i++) 
cout << *(linuxDistro+i)<< endl;

*linuxDistro="WhyCanIchangeThis";// should result in an error but doesnt ? 
for ( int i=0; i < 6; i++) 
cout << *(linuxDistro+i)<< endl;

感谢您的关注!

4

4 回答 4

12

你写

*linuxDistro =  "WhyCanIchangeThis";

这是完全有效的,因为声明linuxDistro

const char *linuxDistro[6];

即它是一个由 6 个指针组成的数组const char。也就是说,您可以更改指针本身,而不能更改这些指针指向的字符。即,你不能编译

*linuxDistro[0] = 'B';

获取字符串"Bebian",因为字符串包含常量字符...

您可能想要的是一个指向常量字符的常量指针数组:

const char *const linuxDistro[6];
于 2012-11-13T06:41:16.827 回答
3

*linuxDistro 仍然是一个指针,是 linuxDistro[0],*linuxDistro="WhyCanIchangeThis"它只是改变指针指向一个新地址,而不是修改旧地址中的内容,这样就可以了。

如果你写**linuxDistro='a',它应该是错误的。

于 2012-11-13T06:44:19.753 回答
1

因为charis not char[],所以当你访问时你访问*char[]的第一个元素(Debian)。

当您移动指针(例如 +1 它)时,您访问数组的下一个元素

这是更好理解的好例子

#include <iostream>
using namespace std;

int main ()
{
  int numbers[5];
  int * p;
  p = numbers;  *p = 10;
  p++;  *p = 20;
  p = &numbers[2];  *p = 30;
  p = numbers + 3;  *p = 40;
  p = numbers;  *(p+4) = 50;
  for (int n=0; n<5; n++)
    cout << numbers[n] << ", ";
  return 0;
}

这将输出:

10, 20, 30, 40, 50,

于 2012-11-13T06:40:31.897 回答
1

因为指针是一个存储内存地址的变量,如果一个指针是const指针一直存储相同的内存地址,所以指针本身的值是不能改变的,但是你对指针所指向的值无话可说,根据您所拥有的,更改指向的值是允许的操作。

于 2012-11-13T06:45:10.147 回答