C语言面试干货——char a[]=“从善若水“ 与 char *p=“从善若水“ 的区别
Posted 从善若水
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C语言面试干货——char a[]=“从善若水“ 与 char *p=“从善若水“ 的区别相关的知识,希望对你有一定的参考价值。
本人就职于国际知名终端厂商,负责modem芯片研发。
在5G早期负责终端数据业务层、核心网相关的开发工作,目前牵头6G算力网络技术标准研究。
文章目录
一、字符串数组的初始化
我们通常使用下面的code进行字符串数组的初始化:
const char arr[] = "Cong Shan Ruo Shui de Blog";
//或者
const char *pt = "Cong Shan Ruo Shui de Blog";
以上两个声明表明,pt与arr都是该字符串的地址。在这两种情况下,带双引号的字符串本身决定了预留给字符串的存储空间。尽管如此,这两种形式不完全相同。
二、“const char arr[] = 字面量 ”与“const char *pt = 字面量 ”的区别
其实本质就是数组与指针的区别
2.1 对于“const char arr[] = 字面量 ”
以上面的声明为例子,数组形式(arr[])在计算机的内存中分配为一个内含27个元素的数组(加上吗,末尾的‘\\0’),每个元素被初始化为字符串字面量对应的字符。
通常,字符串都作为可执行文件的一部分存储在数据段中。当程序载入内存的时候,也载入了程序中的字符串。字符串存储在静态存储区(static memory)中。
但是,程序在开始运行时才会为该数组分配内存。此时,才将字符串拷贝到数组中。注意,此时字符串有两个副本。一个是在静态内存中的字符串字面量,另一个是存储在arr数组中的字符串。
arr是一个常量,不能使用自增访问,但是可以使用类似arr+1的操作
2.2 对于“const char *pt = 字面量 ”
指针形式(*pt)也使得编译器为字符串在静态存储区预留了27个元素的空间。另外,一旦开始执行程序,它会为指针变量pt留出一个存储位置,并把字符串的地址存储在指针变量中。该变量最初指向该字符串的首字符,但是它的值可以改变。
指针pt是变量,所以可以使用递增运算符
大家看一个例子
#include<stdio.h>
#define MSG "Cong shan ruo shui"
int main()
{
const char arr[] = MSG;
const char *pt = MSG;
printf("address of \\"Cong shan ruo shui\\":%p\\n","Cong shan ruo shui");
printf("address of arr :%p\\n",arr);
printf("address of pt :%p\\n",pt);
printf("address of MSG :%p\\n",MSG);
printf("address of \\"Cong shan ruo shui\\":%p\\n","Cong shan ruo shui");
return 0;
}
输出结果如下
- 上面code的输出说明 pt和MSG的地址相同,而arr的地址不同,这与我们前面讨论的内容一致。
- 虽然字符串字面量“Cong shan ruo shui”在程序的两个printf()函数中出现两次,但是编译器只使用了一个存储位置,而且与MSG的地址相同。编译器可以把多次使用的相同字面量存储在一处或多处。另一个编译器可能在不同位置存储3个“Cong shan ruo shui”
- 静态数据使用的存储与arr使用的动态内存不同。不仅值不同,特定编译器甚至使用不同的位数表示两种内存。
以上是关于C语言面试干货——char a[]=“从善若水“ 与 char *p=“从善若水“ 的区别的主要内容,如果未能解决你的问题,请参考以下文章