char strArray[][20] = {"iPhone", "iPod", "iPad", "iWatch"};
printf("%lu\n", sizeof(strArray));
char *str[] = {"iPhone", "iPod", "iPad", "iWatch"};
printf("%lu\n", sizeof(str));
printf("%p\n", str[0]);
//%p 和 str[0], 此时输出的是,指针数组中第一个元素内存储的地址
//%p 和 &str[0],此时输出的是, str[0]自己的物理地址
//输出指针数组 str 中的每一元素(遍历)
for (int i = 0; i < 4; i++) {
printf("%p ", &str[i]);//&str[i]取的是 str[i] 这个指针的地址
printf("%p ", str[i]);// str[i] 取得是 str[i] 中存放的在常量区的地址
printf("%s\n", str[i]);//{*(str + i) 此时是取值的过程} 此时的 str[i] 相当于 char a[] = "iPhone" 中的 a { printf("%s\n", a); }, a 是数组的地址, 而 str[i] 中存放的也是这个地址.只是str[i] 中的地址是常量区的地址, a 的地址是栈区的地址.
}
//将上述指针数组str,升序排序
for (int i = 4; i > 0; i--) {
for (int j = 0; j < i - 1; j++) {
if (strcmp(str[j], str[j + 1]) > 0) {
//比较的是内容
//交换的是指针数组中存储的地址的顺序
char *p = str[j];
str[j] = str[j + 1];
str[j + 1] = p;
}
}
}
for (int i = 0; i < 4; i++) {
printf("%s\n", str[i]);
}
二级指针
最新推荐文章于 2024-07-25 20:20:26 发布