指针也是变量,只不过存储的是内存地址而已,所以可以像普通变量一样存储在数组中。
例子里的声明:
char lineptr[MAXLINES]书上写了,是用MAXLINES个元素的一维数组,数组中的每个元素都是一个指向字符类型对象的指针,lineptr[i]是一个字符指针(也就是地址),lineptr[i]是该指针指向的第i个文本行的首字符。
这个比较难理解,就是什么样的定义是指针数组。
数组声明可以直接就是字符。这就是一个数组,数组名就是这个字符。然后对其进行偏移量的计算后,就可以进行指向加减操作。而指针数组字符的同时还要加一个正常数组的范围。变成了普通数组。但本质还是指针。(这太乱套了,得捋捋)
也可以理解成这个数组里的每个元素都是一个数组(也就是首字符的指针)
这个例子main函数部分不需要看什么,读取输入行并记录行数,排序,然后就是输出了。它下面的几个函数是比较重要的。
其中最复杂的就是读取文本的函数。
getline前面有,就是读取输入行。然后返回输入行大小。alloc就是返回一个指定大小空间的开头的指针(大小以括号内的数值为准)。
这里我还是捋一遍吧,因为我也看了好几次。
开头用getline读取输入行,然后返回输入行大小给len,之后对0进行比较。大于0就是有价值的文本行。
然后判断现在已经有的输入行数是否大于限定的最大输入行数。或者有没有足够的空间(alloc是返回一个len大小的指针如果空间不够回返回NULL,)将已经得到指定大小空间的指针给p。
如果这俩有一个不满足条件就返回-1.
如果条件允许,将读取的输入行,getline中的line参数的换行符去掉变成独立的行。
然后用strcpy函数将line复制到p。
然后再把指针p放入指针数组lineptr里面。
最后返回目前的输入行数。
输出的没什么好写的。循环输出而已。
之后这个排序之前就有。而且没什么改变。本来不想写(太懒)想一想还是写了吧。也不浪费什么时间。
首先传递给函数的是三个参数,第一个就是指针数组。第二个是0,第三个是总行数。
然后就是定义个函数swap,没什么特别的,改变数组两个元素的位置。
首先判断是否还有需要排序的数,小于两个当然不用排序。
swap将中间的基准数提取出来放到首位。
然后将最左侧的位置拷贝,用于排序。
接下来就是判断。最左侧+1将基准值略过,终止条件是到最右侧。
strcmp函数是对比两个数组的数,相等返回0,。第一个参数小于第二个参数返回负数,第一个参数大于第二个参数返回正数。
这里就是对比当前数是否小于基准值,如果是那么进行排序操作,将其放到基准值左侧。
然后引用自身。
指针数组以及指向指针的指针
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...