詳解C語(yǔ)言學(xué)習(xí)記錄之指針
1指針是什么
指針是匯編語(yǔ)言中的一個(gè)對(duì)象,利用地址,指向存在電腦存儲(chǔ)器中的另一個(gè)地方的值。由于通過(guò)地址能找到所需的變量單元,地址指向該變量單元。因此,將地址形象的稱為指針。意思是通過(guò)它能找到以它為地址的內(nèi)存單元。
int main() { int a = 10;//在內(nèi)存中開(kāi)辟一個(gè)空間 int* p = &a;//這里我們對(duì)變量a,取出它的地址,可以使用&操作符 //將a的地址存放到p變量中,p就是一個(gè)指針變量。 return 0; }
==>指針就是變量,存放地址的變量。(存放在指針中的值當(dāng)作地址處理)
- 指針的大小是固定的4/8個(gè)字節(jié)(32位平臺(tái)/64位平臺(tái))
2指針和指針類型
指針類型決定了指針進(jìn)行解引用操作的時(shí)候,能夠訪問(wèn)空間的大小。
int*p; *p
能夠訪問(wèn)4個(gè)字節(jié)char*p; *p
能夠訪問(wèn)一個(gè)字節(jié)double*p; *p
能夠訪問(wèn)8個(gè)字節(jié)
指針類型決定了:指針走一步走多遠(yuǎn)(指針的步長(zhǎng)),對(duì)應(yīng)上邊
3野指針
(1)三種情況
1.指針未初始化
2.指針越界訪問(wèn)
int main() { int arr[10] = { 0 }; int* p = arr; int i = 0; for (i = 0;i < 11;i++) { //當(dāng)指針指向的范圍超出數(shù)組arr的范圍時(shí),p就是野指針 *(p++) = i; } return 0; }
3.指針指向的空間釋放
(2)如何規(guī)避野指針
- 指針初始化
- 小心指針越界
- 指針指向空間釋放即使置NULL
- 指針使用之前檢查有效性
4指針運(yùn)算
- 指針 加減 整數(shù)
- 指針 減 指針
- 指針的運(yùn)算關(guān)系
5指針和數(shù)組
- 整型數(shù)組,存放整型
- 字符數(shù)組,存放字符
- 指針數(shù)組,存放指針
int main() { int a = 10; int b = 20; int c = 30; int* arr[3] = { &a,&b,&c };//指針數(shù)組 int i; for (i = 0;i < 3;i++) { printf("%d\n", *(arr[i])); } }
6字符指針
char*;
示例:
int main() { const char* p = "abcdef";//"abcdef"是一個(gè)常量字符串 printf("%c\n", *p);//p是字符串"abcdef"的首元素a的地址 printf("%s\n", p); return 0; }
結(jié)果:
7數(shù)組指針
存儲(chǔ)數(shù)組地址
int main() { //int *p=NULL;//p是整型指針 //char* pc = NULL;//pc是字符指針 //int arr[10] = { 0 }; //arr首元素地址 //&arr[0]首元素地址 //&arr數(shù)組地址 int arr[10] = { 1,2,3,4,5,6,7,8,9,10 }; int (*p)[10] = &arr;//[]優(yōu)先級(jí)高于*所以要用()。此時(shí)p為數(shù)組指針。存儲(chǔ)數(shù)組的地址 return 0; }
8指針數(shù)組
指針數(shù)組是存放指針的數(shù)組
int main() { int arr1[] = { 1,2,3,4,5 }; int arr2[] = { 2,3,4,5,6 }; int arr3[] = { 3,4,5,6,7 }; int* parr[] = { arr1,arr2,arr3 };//parr為數(shù)組指針,將數(shù)組名(數(shù)組首元素地址)放入其中 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"); } return 0; }
9其他
(1)
int arr[10]={1,2,3,4,5,6,7,8,9,10}; int* p=arr;
// arr[i] == *(arr+i) == *(p+i) ==p[i]
(2)
int arr[5]; int *parr1[10]; int (*parr2)[10]; int (*(parr3[10]))[5];
- arr是一個(gè)有5個(gè)元素的整型數(shù)組。
- parr1是一個(gè)數(shù)組,數(shù)組有10個(gè)元素,每個(gè)元素的類型是int*,parr1是指針數(shù)組。
- parr2是一個(gè)指針,該指針指向一個(gè)數(shù)組,數(shù)組有10個(gè)元素,每個(gè)元素都是int,parr2是數(shù)組指針。
- parr3是一個(gè)數(shù)組,該數(shù)組有10個(gè)元素,每個(gè)元素是一個(gè)數(shù)組指針,該數(shù)組指針指向的數(shù)組有5個(gè)元素,每個(gè)元素都是int。
總結(jié)
本篇文章就到這里了,希望能夠給你帶來(lái)幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
深入理解C++中的new和delete并實(shí)現(xiàn)對(duì)象池
這篇文章主要介紹了C++中的new和delete并實(shí)現(xiàn)對(duì)象池,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-09-09C程序?qū)崿F(xiàn)整數(shù)的素?cái)?shù)和分解問(wèn)題
這篇文章主要介紹了C程序?qū)崿F(xiàn)整數(shù)的素?cái)?shù)和分解問(wèn)題,對(duì)于算法的學(xué)習(xí)有不錯(cuò)的借鑒價(jià)值,需要的朋友可以參考下2014-09-09C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)遞歸之斐波那契數(shù)列
這篇文章主要介紹了C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)遞歸之斐波那契數(shù)列的相關(guān)資料,希望通過(guò)本文能幫助到大家,讓大家理解掌握這部分內(nèi)容,需要的朋友可以參考下2017-10-10Qt下調(diào)用vlc庫(kù)實(shí)現(xiàn)RTSP拉流播放和截圖過(guò)程詳解
這篇文章主要為大家介紹了Qt下調(diào)用vlc庫(kù)實(shí)現(xiàn)RTSP拉流播放和截圖過(guò)程詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08C++實(shí)現(xiàn)LeetCode(167.兩數(shù)之和之二 - 輸入數(shù)組有序)
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(167.兩數(shù)之和之二 - 輸入數(shù)組有序),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-08-08使用UART與PC通信實(shí)現(xiàn)msp430g2553單片機(jī)超聲波測(cè)距示例
這篇文章主要介紹了使用UART與PC通信實(shí)現(xiàn)msp430g2553單片機(jī)超聲波測(cè)距示例,需要的朋友可以參考下2014-05-05北郵計(jì)算機(jī)考研復(fù)試題的C語(yǔ)言解答精選
這篇文章主要介紹了北郵計(jì)算機(jī)考研復(fù)試題目的C語(yǔ)言解答精選,選自2012年的一些基礎(chǔ)的上機(jī)題目,需要的朋友可以參考下2015-08-08c++ sqlite3如何利用事務(wù)(BEGIN;COMMIT;)批量操作
這篇文章主要介紹了c++ sqlite3如何利用事務(wù)(BEGIN;COMMIT;)批量操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08C語(yǔ)言實(shí)現(xiàn)鏈表與文件存取的示例代碼
這篇文章主要和大家分享C語(yǔ)言實(shí)現(xiàn)鏈表與文件存取的示例代碼,可以實(shí)現(xiàn)建立鏈表,然后把鏈表數(shù)據(jù)存儲(chǔ)到文件中,然后把文件數(shù)據(jù)存儲(chǔ)到數(shù)組中并輸出,感興趣的可以學(xué)習(xí)一下2022-04-04