字串指標陣列詳解
阿新 • • 發佈:2019-01-27
1.基本操作
#include <stdio.h>
int main(void)
{
char *str[] = {"abg","cd"};//*單獨拿出來,指的是數組裡的內容是*型的,str的型別是char *[]型
printf("%c\n",*(*(str+1)+1));//d
printf("%c\n",**str);//a
printf("%s\n",*str+1);//bg
printf("%s\n",*(str+1));//cd,
printf("%s\n",str[0]);//abg
printf("%p\n",&str );//陣列整體的收地址,大小同下行程式碼的值
printf("%p\n",str);//陣列的首地址,即存放內容——字串"abg"的地址,並非'a'的地址
return 0;
}
/*
指標陣列相當於二位陣列
str-->"abg"的地址,str+1 --->"cd"的地址
*str-->"abg"的首地址,即'a'的地址,*(str+1)--->"cd"的首地址,即'c'的地址
*(str+1)+1--->"cd"的首地址+1,即'd'的地址
*(*(str+1)+1)--->對'd'的地址取值,即為'd'
**str-->'a'
*/
執行結果如下:
2.傳參問題
#include <stdio.h>
char **String(char *str[])
{
str[0] = "aa";
str[1] = "bb";
return str;
}
//返回*str[]時,因為[]是下標運算子號,可以當作*,所以返回值類新為char **
int main(void)
{
char **p;
char *str[2];
p = String(str);
printf("%s\n",*p);
printf("%s\n" ,*(p+1));
return 0;
}