2
头图

1. 背景

下面两种方式定义和初始化的数组有什么区别呢?

char *str1 = "abcd";
char str2[10] = "abcd";

2. 内存分配方式区别

这里涉及指针指向常量字符串时和使用常量内存初始化数组的区别。为了节省内存,C/C++把常量字符串放到单独的一个内存区域。当几个指针赋值给相同的常量字符串时,它们实际上会指向相同的内存地址。而用常量内存初始化数组,则会把常量字符串内容拷贝到数组开辟的内存。

char *str1 = "abcd";
char *str2 = "abcd";
if(str1 == str2){
    //相等
    printf("str1 equal str2");
}

3. 修改字符串内容区别

对于char str[] = "123";形式的字符串,可以通过数组下标的方式修改字符串内容:str[1] = 'a';,如果是指针方式:

char *str = "123";
str[0] = 'a';

会报错:EXC_BAD_ACCESS (code=2, address=0x100003f11)

分析一下原因:指针方式无法修改字符串内容,因为这个字符串存放在内存的常量区;数组方式可以修改字符串内容,因为这个字符串是存放在栈中的。

指针方式计算机操作步骤:

  1. 程序加载字符串值,并存放到常量存储区,常量存储器的内容是只读的;
  2. 程序在栈上创建 str变量;
  3. 将 str变量设置为 "123" 的地址;
  4. 若程序试图修改 str变量所指向的字符串内容就会报错,因为字符串在常量存储器,是只读的。

数组方式计算机操作步骤:

  1. 程序加载字符串值,并存放到常量存储区,常量存储器的内容是只读的;
  2. 程序在栈上初始化一个数组(分配空间),并自动保证该数组足够大以容纳字符串;
  3. 程序将字符串的内容复制到栈的数组内。

轻口味
16.9k 声望3.9k 粉丝

移动端十年老人,主要做IM、音视频、AI方向,目前在做鸿蒙化适配,欢迎这些方向的同学交流:wodekouwei