1.以字符串形式出现的,编译器都会为该字符串自动添加一个0作为结束符,如在代码中写"abc",那么编译器帮你存储的是"abc\0"
2."abc"是常量吗?
答案:有时是,有时不是
不是常量的情况:
"abc"作为字符数组初始值的时候就不是,如
char str[] = "abc";
因为定义的是一个字符数组,所以就相当于定义了一些空间来存放"abc",而又因为字符数组就是把字符一个一个地存放的,所以编译器把这个语句解析为
char str[3] = {'a','b','c'};
又根据上面的总结1,所以char str[] = "abc";的最终结果是
char str[4] = {'a','b','c','\0'};
做一下扩展,如果char str[] = "abc";是在函数内部写的话,那么这里的"abc\0"因为不是常量,所以应该被放在栈上。
是常量的情况:
把"abc"赋给一个字符指针变量时,如
char* ptr = "abc";
因为定义的是一个普通指针,并没有定义空间来存放"abc",所以编译器得帮我们找地方来放"abc",显然,把这里的"abc"当成常量并把它放到程序的常量区是编译器最合适的选择。所以尽管ptr的类型不是const char*,并且ptr[0] = 'x';也能编译通过,但是执行ptr[0] = 'x';就会发生运行时异常,因为这个语句试图去修改程序常量区中的东西。
记得哪本书中曾经说过char* ptr = "abc";这种写法原来在c++标准中是不允许的,但是因为这种写法在c中实在是太多了,为了兼容c,不允许也得允许。虽然允许,但是建议的写法应该是 const char* ptr = "abc";这样如果后面写ptr[0] = 'x'的话编译器就不会让它编译通过,也就避免了上面说的运行时异常。
又扩展一下,如果char* ptr = "abc";写在函数体内,那么虽然这里的"abc\0"被放在常量区中,但是ptr本身只是一个普通的指针变量,所以ptr是被放在栈上的,只不过是它所指向的东西被放在常量区罢了。
3.字符串常量的类型可以理解为相应字符常量数组的类型,如"abcdef"的类型就可以看成是const char[7]
4.
如果真的需要使用"abcd"作为指针,建议写为const char * p="abcd";
如果是初始化字符串数组,建议写为char p[]="abcd";
如果p为指针,需要初始化,应该是char *p;p=malloc(STR_SIZE);strcpy(p,"abcd");
分享到:
相关推荐
在探讨`char* ps="abc";`这一定义时,我们首先需要理解这行代码所代表的具体含义及其背后涉及的关键概念。这句话表示`ps`是一个指向常量字符串的指针,而该字符串的内容为"abc"。为了更好地理解这句话,我们可以从...
unsigned char *input = "abc"; int ilen = 3; unsigned char output[32]; int i; sm3_context ctx; printf("Message:\n"); printf("%s\n",input); sm3(input, ilen, output); printf("Hash:\n "); for...
(2) char* constp char const* p constchar*p上述三个有什么区 别? 答案: char * const p; // 常量指针,p的值不可以修改 char const* p; //指向常量的指针,指向的常量值不可以改const char *p; //和 char const *p...
char * const p、char const * p、const char *p三者的区别: * char * const p:常量指针,p的值不可以修改 * char const * p:指向常量的指针,指向的常量值不可以修改 * const char *p:指向字符的指针,该指针...
2. 指针常量:char * const p; // 常量指针,p 的值不可以修改 char const * p; // 指向常量的指针,指向的常量值不可以改 const char *p; // 和 char const *p 3. 数组和指针:char str1[] = "abc"; char str2[] =...
18. **运算符优先级**:`*`的优先级高于`<=`、`*=`和`+`。 19. **运算符优先级**:`?:`(三目运算符)的优先级最低,低于`!`、`&&`和`!=`。 20. **自增运算**:`i+++j`先自增`i`,然后加上`j`,所以结果是3。 21. **...
char const * p 是一个指向常量的指针,指针所指向的值不能修改,但指针的值可以修改。const char *p 是一个指向常量的指针,指针所指向的值不能修改,但指针的值也不能修改。 3. 数组: 数组是一种数据结构,用于...
p=p+1;`这样的操作是不被允许的,因为数组的地址不可修改。而`p[0]=1;`则是允许的,因为可以修改数组内容。对于指针,如`int *p; p=p+1;`是合法的,但`p[0]=1;`在未初始化指针的情况下是不允许的。此外,字符指针`...
这三个声明的指针的区别在于,第一个是常量指针,p的值不可以修改;第二个是指向常量的指针,指向的常量值不可以改;第三个和第二个相同。 3. 数组和指针: char str1[] = "abc"; char str2[] = "abc"; const ...
"深入分析C++中char和char []的区别" 本文将深入分析C++中char和char []的区别,探讨其在内存中的存储方式和使用场景。 首先, lets 看看下面的代码: ```c char *c1 = "abc"; char c2[] = "abc"; char *c3 = ...
char *str = "abc"; 关于指针: 与指针有关的各种说明和意义见下表。 int *p; p为指向整型量的指针变量 int *p[n]; p为指针数组,由n个指向整型量的指针元素组成。 int (*p)[n]; p为指向整型二维数组的指针变量,二...
在指针的使用中,char * const p、char const * p、const char *p三个声明的区别在于:char * const p是常量指针,p的值不可以修改;char const * p是指向常量的指针,指向的常量值不可以改;const char *p是指向...
2. void setmemory(char p, int num) { *p=(char *) malloc(num);} void test(void) { char *str=NULL; getmemory(&str,100); strcpy(str,"hello"); printf(str); } 运行 test 函数将输出“hello”,因为strcpy(str,...
前言 C语言返回字符串函数共有四种方式,分别如下: 使用堆空间,返回申请的堆地址,注意释放 函数参数传递指针,返回该指针 ... strcpy ( s , "abc " ); return s; } 但这种方式需要注意,必须由使
2. 指针:char * const p; //常量指针,p 的值不可以修改 char const * p;//指向常量的指针,指向的常量值不可以改 const char *p; //和 char const *p 指针是指向内存地址的变量,char * const p; 是一个常量...
根据给定的信息,本文将对“维吉尼亚的纯C算法实现”进行详细的解析与介绍。维吉尼亚算法(Vigenère cipher)是一种多字母表替换密码,它使用一系列交错的凯撒密码来加密文本,这使得密码分析变得更加困难。在下面...
在C++中,虽然 `#import` 可以被某些编译器支持作为非标准扩展,但它与 `#include` 类似,其主要区别在于 `#import` 保证一个文件只被导入一次,从而避免了头文件被重复包含的问题。这种方式可以提高大型项目的编译...
2. void setmemory(char p, int num) { *p=(char *) malloc(num);} void test(void) { char *str=NULL; getmemory(&str,100); strcpy(str,"hello"); printf(str); } 运行 test 函数将输出 "hello",因为 getmemory ...
char a[15] = "abc"; char *b; b = strchr(a, 'b'); ``` 这里,`b`将指向`a`中的'b'。 ### 4. `strcmp` - 字符串比较 `strcmp`函数用于比较两个字符串。如果两个字符串相等,返回0;如果第一个字符串小于第二个...