欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語(yǔ)言入門(mén)之指針用法教程

 更新時(shí)間:2014年09月02日 11:31:40   投稿:shichen2014  
這篇文章主要介紹了C語(yǔ)言入門(mén)之指針用法教程,主要對(duì)C語(yǔ)言中指針的本質(zhì)及常見(jiàn)用法做了較為通俗易懂的分析,是后續(xù)深入學(xué)習(xí)C語(yǔ)言的基礎(chǔ),需要的朋友可以參考下

本文針對(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í)例

    這篇文章主要介紹了C++進(jìn)程共享數(shù)據(jù)封裝成類(lèi)的方法,以實(shí)例形式講述了其封裝代碼與具體用法,具有一定的實(shí)用價(jià)值,需要的朋友可以參考下
    2014-10-10
  • C++實(shí)現(xiàn)LeetCode(53.最大子數(shù)組)

    C++實(shí)現(xiàn)LeetCode(53.最大子數(shù)組)

    這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(53.最大子數(shù)組),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • C++在非面向?qū)ο蠓矫鎸?duì)C語(yǔ)言的擴(kuò)充

    C++在非面向?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-05
  • C++ STL_vector 迭代器失效問(wèn)題的解決方法

    C++ 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-08
  • C++深入講解new與deleted關(guān)鍵字的使用

    C++深入講解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-05
  • VC創(chuàng)建進(jìn)程CreateProcess的方法

    VC創(chuàng)建進(jìn)程CreateProcess的方法

    這篇文章主要介紹了VC創(chuàng)建進(jìn)程CreateProcess的方法,涉及VC操作進(jìn)程的基本技巧,需要的朋友可以參考下
    2015-05-05
  • OpenCV圖像特征提取之Shi-Tomasi角點(diǎn)檢測(cè)算法詳解

    OpenCV圖像特征提取之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-09
  • C++使用一棵紅黑樹(shù)同時(shí)封裝出map和set實(shí)例代碼

    C++使用一棵紅黑樹(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-04
  • Qt網(wǎng)絡(luò)編程實(shí)現(xiàn)TCP通信

    Qt網(wǎng)絡(luò)編程實(shí)現(xiàn)TCP通信

    這篇文章主要為大家詳細(xì)介紹了Qt網(wǎng)絡(luò)編程實(shí)現(xiàn)TCP通信,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • C++編程語(yǔ)言實(shí)現(xiàn)單鏈表詳情

    C++編程語(yǔ)言實(shí)現(xiàn)單鏈表詳情

    這篇文章主要介紹的是利用C語(yǔ)言實(shí)現(xiàn)單鏈表,實(shí)現(xiàn)的是鏈表中最簡(jiǎn)單的一種單鏈表且每個(gè)結(jié)點(diǎn)中只含有一個(gè)指針域,下面將詳細(xì)舉例說(shuō)明,需要的朋友可以參考一下
    2021-10-10

最新評(píng)論