1. 背景与基本原理 在一些场合下,用户往往需要动态输入字符串,如果程序能够自动接收传进的字符串并进行计数,便可以达到动态接收的效果。基本原理是定义一个指向字符串指针的指针,对其进行进一步细化。我们期待程序能够接收未知数量、未知长度的字符串,能够动态保存字符串。如图1所示,设计一个这样的结构便可以达成以上要去。
图1 字符串在内存中的排布基本思想如下,存放一个字符串,需要一定的内存空间(如图中最右边的部分),而这段空间需要有一个地址指向它(如图1中中间部分),图1中中间部分的内存中存放着指向字符串内存的地址(紫色地址)。当有多个字符串时,需要指向多个存放字符串的内存,因此将这些地址组合起来,存放在一段内存中。而这个内存也需要一个地址指向它,即图1中黄色地址。
2. 数据结构整理我们知道指向一个字符串的地址为:
![4086bd671cd6d6ba5c9731ed31a2e8ee.png](https://i-blog.csdnimg.cn/blog_migrate/3c99ce49811c51a84199d7c5490c767a.png)
char* str;
再有多个字符串时,该地址就会有多个,将其组合起来。最简单的思路时将其存放在一个数组中,例如:
char* str_arr[9];
该数组有9个元素,每一个元素存放的是指向字符串的内存的地址。但是这种方