![6e0f07c631ce5b7c8f84324c11f963de.png](https://i-blog.csdnimg.cn/blog_migrate/62f739200039ae48e194097556e674b6.jpeg)
在C语言中有两种使用字符串的方式,用char型指针、用char型数组。那他们有什么区别和联系呢,下面来一起来说说:
C语言表示字符串的两种方式,如下:
![e70d13f2895deb8b50df5324d23f6c90.png](https://i-blog.csdnimg.cn/blog_migrate/9e97bc6953c150120f89ee242512d38d.jpeg)
首先,任何常量都将被放置到一个固定的内存区域,叫 .rodata 区,也叫常量区。因此上述代码中的 "abcde" 和 "uvxyz" 都被放置在这里面。
其次,s1 和 s2 都是普通变量,都被放置在栈内存中。
然后,s1 是一个指针,因此它的尺寸大小永远都是四字节(32位系统),而 s2 是一个数组,尺寸大小根据具体的内容来决定。
它们变量在内存中的关系如下图:
![8d21a36addce711df8b0d60f18445627.png](https://i-blog.csdnimg.cn/blog_migrate/e2953185d7adb48a96f86a94d9905bef.jpeg)
对于 s1 而言,仅仅保留了一个地址0x123,该地址就是常量区中字符串 "abcde" 的地址。
对于 s2 而言,则保留了从常量区复制过来了字符串本身的内容 "uvxyz" ,从上图看到,此时 "uvxyz“ 实际上有两个副本。
那么在程序中如何使用这两种方式呢?答案很简单,如果仅仅是使用字符串,而不需要修改它,那就使用指针就行了,但是如果涉及需要对字符串内容的修改,那么就需要使用数组。
![c495fedcecc406abc0d27f4d1f307d83.png](https://i-blog.csdnimg.cn/blog_migrate/780122c49b2c1dd36bfe6effd5b1875a.jpeg)
上述代码中,第一行试图将 "ABCDE" 塞到常量区,显然是不可行的。而第二行则试图将 "UVXYZ" 塞入栈中的数组,这是可行的。
char型数组和char型指针是有本质上的区别的,大家千万不要搞混。