1.字符指針

2指針數組
3.數組指針
1.字符指針----指向字符的指針例1:
int main()
{
char ch = 'w';
char* pc = &ch;
return 0;
}例2:
int main()
{
char arr[] = "abcdef";
不是把abcdef放到指針p里,指針沒有那么大的空間能存儲整個字符串
而是內存中放有一個常量字符串 abcdef ,
然后把a的地址賦值給p
char* pc = arr;
printf("%s\n", pc);
printf("%s\n", arr);
return 0;
}現在p指向的就是字符串“abcdef”
那么能不能更改字符串呢?
*p = 'w';這樣做對嗎 , 不對,因為常量字符串無法更改
最準確的寫法如下:
const char* p = "abcdef";const修飾之后,字符串就無法更改了
面試題:
int main()
{
char arr1[] = “abcdef”;
char arr2[] = “acbdef”;
char* p1 = “abcdef”;
char* p2 = “abcdef”;
if (arr1 == arr2)
{
printf(“arr1 and arr2 are same\n”);
}
else
{
printf(“arr1 and arr2 are not same\n”);
}
if (p1 == p2)
{
printf(“p1 and p2 are same\n”);
}
else
{
printf(“p1 and p2 are not same\n”);
}
return 0;
}
運行結果如下:
原因:arr1和arr2所在地址不同,
兩個指針所指向的字符串一模一樣,指向的是同一塊空間的地址
2.指針數組:是數組,用來存放指針的int main()
{
int arr[10] = { 0 };//整型數組
char ch[5] = { 0 };//字符數組
int *parr[4];//存放整型指針的數組
char * pch[5];//存放字符指針的數組
return 0;
}整型指針數組的用法
例1
int main()
{
int a = 10;
int b = 20;
int c = 30;
int* p[3] = { &a,&b,&c };
//這是一個數組名為p的數組,該數組的元素是int*類型
}例2
int main()
{
int arr1[] = { 1,2,3,4,5 };
int arr2[] = { 6,7,8,9,10 };
int arr3[] = { 3,4,5,6,7};
int* parr[3] = { arr1,arr2,arr3 };
int i = 0;
for (i = 0; i< 3; i++)
{
int j = 0;
for (j = 0; j< 5; j++)
{
printf("%d ", *(parr[i] + j));
}
printf("\n");
}
} 3.數組指針---指針就像整型指針,指向的是整型的地址
就像字符指針,指向的是字符的地址
所以數組指針,是指向數組的地址,該指針存放的是數組首元素地址
例1:
int main()
{
int arr[10] = {1,2,3,4,5,6,7,8,9,10};
int (*p)[10] =&arr;//數組的地址要存起來
//因為[]的優先級高于 *
}數組指針的用法–用到二維數組指針以上才方便
void print(int (*p)[5],int x, int y)
{
for (int i = 0; i< x; i++)
{
for (int j = 0; j< y; j++)
{
printf("%d ", *(*(p + i) + j));
}
}
}
int main()
{
int arr[3][5] = { {1,2,3,4,5},{2,3,4,5,6}, {3,4,5,6,7} };
//arr - 數組名 - 數組名是首元素地址
print(arr, 3, 5);
}這里arr是元素1的地址嗎? 不是
arr為二維數組時,要先把二維數組想象成一維數組(降一維)
相當于每一行是一個元素
既然arr是第一行的地址,那么傳參的時候,就用數組指針來接收
總結:
你是否還在尋找穩定的海外服務器提供商?創新互聯www.cdcxhl.cn海外機房具備T級流量清洗系統配攻擊溯源,準確流量調度確保服務器高可用性,企業級服務器適合批量采購,新人活動首月15元起,快前往官網查看詳情吧
新聞名稱:c語言---指針進階(1)-創新互聯
文章位置:http://www.yijiale78.com/article40/psjeo.html
成都網站建設公司_創新互聯,為您提供云服務器、企業網站制作、網站收錄、網站設計、靜態網站、App開發
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯