C語(yǔ)言入門(mén)之指針用法教程
本文針對(duì)C語(yǔ)言初學(xué)者詳細(xì)講述了指針的用法,并配以實(shí)例進(jìn)行說(shuō)明。具體分析如下:
對(duì)于C語(yǔ)言初學(xué)者來(lái)說(shuō),需要明白指針是啥?重點(diǎn)就在一個(gè)“指”上。指啥?指的地址。啥地址??jī)?nèi)存的地址。
上面說(shuō)明就是指針的本質(zhì)了。
這里再詳細(xì)解釋下。數(shù)據(jù)存起來(lái)是要存在內(nèi)存里面的,就是在內(nèi)存里圈出一塊地,在這塊地里放想放的東西。變量關(guān)心的是這塊地里放的東西,并不關(guān)心它在內(nèi)存的哪里圈的地;而指針則關(guān)心這塊地在內(nèi)存的哪個(gè)地方,并不關(guān)心這塊地多大,里面存了什么東西。
指針怎么用呢?下面就是基本用法:
int a, b, c; double f; int *pt_a = &a, *pt_b = &b, *pt_c = &c; double *pt_f = &f;
上面兩行聲明了三個(gè)int類(lèi)型的變量a,b,c,一個(gè)double類(lèi)型的變量f。下面就是指針的用法了,聲明變量的時(shí)候只需要在變量前面加上“*”這個(gè)符號(hào)就說(shuō)明了這個(gè)變量是指針,而前面的“int”說(shuō)明指針指向的內(nèi)存里面存放著int類(lèi)型的變量。
變量和指針的聲明也可以放到一起:
int a, b, c; double f; int other, *pt_a = &a, *pt_b = &b, *pt_c = &c; double x = 0, *pt_f = &f;
然后就是新的運(yùn)算符——“&”了。是不是很熟悉?沒(méi)錯(cuò),這個(gè)就是scanf里面的那個(gè)“&”。它是取地址符,即用在變量前面使用這個(gè)運(yùn)算符,能夠獲得這個(gè)變量在內(nèi)存里面的地址。由此就可以解釋scanf雙引號(hào)后面為何要使用“&”了,就是將前面按照格式讀進(jìn)來(lái)的數(shù)據(jù),按照后面給出的地址直接填進(jìn)內(nèi)存里,所以scanf雙引號(hào)后面提供的參數(shù)實(shí)質(zhì)上并不是希望賦值的變量,而是希望保存數(shù)據(jù)的地址。所以,例如如果有int類(lèi)型的變量a,同時(shí)有指向它的指針pt,那么下面兩句是等效的:
scanf("%d", &a); scanf("%d", pt);
回到指針,接下來(lái)就是修改指針指向變量的值了,怎么弄呢?下面就是例子:
int a; int *pt = &a; *pt = 123; // 該語(yǔ)句等同于 a = 123;
不要把“*”給忘了哈。
至于這個(gè)“*”符號(hào),可以這么理解:需要用到指針指向的內(nèi)容時(shí),加上“*”,此時(shí)它等同于一個(gè)變量;只是需要指針的地址時(shí),不需要加“*”,此時(shí)它代表內(nèi)存的地址。
而指針也可以改變它指向的地址:
int a, b, c; int *pt_a = &a, *pt_b = &b; pt_b = &c; pt_a = pt_b;
很多教材都在強(qiáng)調(diào)野指針的問(wèn)題,什么叫野指針?呃……可以叫做“撒野”的指針。什么意思呢?舉個(gè)例子,如果聲明了一個(gè)指針pt,而沒(méi)讓他指向任何變量,那么它指向哪里呢?答案是:不確定,整個(gè)內(nèi)存哪里都有可能被它指到。如果此時(shí)修改它指向的內(nèi)容,而它恰好指向了系統(tǒng)某個(gè)關(guān)鍵的進(jìn)程……那后果就比較嚴(yán)重了。所以指針用之前一定讓它指點(diǎn)東西。如果想讓它什么都不指,怎么辦?很簡(jiǎn)單,指向NULL即可。
這就是指針了。可能看完很多人會(huì)覺(jué)得本來(lái)用變量你又加了個(gè)指針指不是更麻煩?我要說(shuō)的是,這只是最基本的用法。C語(yǔ)言的數(shù)組中,還有一些復(fù)雜的數(shù)據(jù)結(jié)構(gòu)都需要用到指針。所以這些基礎(chǔ)的東西還是有必要加以熟練掌握的。
希望本文所述對(duì)大家C語(yǔ)言程序設(shè)計(jì)的學(xué)習(xí)有所幫助。
相關(guān)文章
C++進(jìn)程共享數(shù)據(jù)封裝成類(lèi)實(shí)例
這篇文章主要介紹了C++進(jìn)程共享數(shù)據(jù)封裝成類(lèi)的方法,以實(shí)例形式講述了其封裝代碼與具體用法,具有一定的實(shí)用價(jià)值,需要的朋友可以參考下2014-10-10C++實(shí)現(xiàn)LeetCode(53.最大子數(shù)組)
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(53.最大子數(shù)組),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07C++在非面向?qū)ο蠓矫鎸?duì)C語(yǔ)言的擴(kuò)充
C++是一種面向?qū)ο缶幊陶Z(yǔ)言,但它也可以作為C語(yǔ)言的擴(kuò)展語(yǔ)言。在C++中,我們可以使用非面向?qū)ο蠓矫娴奶匦詠?lái)擴(kuò)展C語(yǔ)言。在本文中,我們將討論C++在非面向?qū)ο蠓矫鎸?duì)C語(yǔ)言的擴(kuò)充2023-05-05C++ STL_vector 迭代器失效問(wèn)題的解決方法
迭代器的主要作用就是讓算法能夠不用關(guān)心底層數(shù)據(jù)結(jié)構(gòu),其底層實(shí)際就是一個(gè)指針,或者是對(duì)指針進(jìn)行了封裝,迭代器失效,實(shí)際就是迭代器底層對(duì)應(yīng)指針?biāo)赶虻目臻g被銷(xiāo)毀了,對(duì)迭代器失效我們了解了,那么現(xiàn)在我們就分析,在vector中哪些操作會(huì)導(dǎo)致迭代器失效2023-08-08C++深入講解new與deleted關(guān)鍵字的使用
這篇文章主要介紹了C++中new與deleted關(guān)鍵字的使用,new在動(dòng)態(tài)內(nèi)存中為對(duì)象分配空間并返回一個(gè)指向該對(duì)象的指針;delete接受一個(gè)動(dòng)態(tài)對(duì)象的指針, 銷(xiāo)毀該對(duì)象, 并釋放與之關(guān)聯(lián)的內(nèi)存2022-05-05VC創(chuàng)建進(jìn)程CreateProcess的方法
這篇文章主要介紹了VC創(chuàng)建進(jìn)程CreateProcess的方法,涉及VC操作進(jìn)程的基本技巧,需要的朋友可以參考下2015-05-05OpenCV圖像特征提取之Shi-Tomasi角點(diǎn)檢測(cè)算法詳解
Harris角點(diǎn)檢測(cè)算法就是對(duì)角點(diǎn)響應(yīng)函數(shù)R進(jìn)行閾值處理,Shi-Tomasi原理幾乎和Harris一樣的,只不過(guò)最后計(jì)算角點(diǎn)響應(yīng)的公式發(fā)生了變化。本文將和大家詳細(xì)說(shuō)說(shuō)Shi-Tomasi角點(diǎn)檢測(cè)算法的原理與實(shí)現(xiàn),需要的可以參考一下2022-09-09C++使用一棵紅黑樹(shù)同時(shí)封裝出map和set實(shí)例代碼
紅黑樹(shù)(Red?Black?Tre)是一種自平衡二叉查找樹(shù),是在計(jì)算機(jī)科學(xué)中用到的一種數(shù)據(jù)結(jié)構(gòu),典型的用途是實(shí)現(xiàn)關(guān)聯(lián)數(shù)組,下面這篇文章主要給大家介紹了關(guān)于C++使用一棵紅黑樹(shù)同時(shí)封裝出map和set的相關(guān)資料,需要的朋友可以參考下2023-04-04Qt網(wǎng)絡(luò)編程實(shí)現(xiàn)TCP通信
這篇文章主要為大家詳細(xì)介紹了Qt網(wǎng)絡(luò)編程實(shí)現(xiàn)TCP通信,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-08-08