99精品伊人亚洲|最近国产中文炮友|九草在线视频支援|AV网站大全最新|美女黄片免费观看|国产精品资源视频|精彩无码视频一区|91大神在线后入|伊人终合在线播放|久草综合久久中文

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

面試中的高頻問題:指針函數(shù)與函數(shù)指針,你能完美應(yīng)對嗎?

朱老師物聯(lián)網(wǎng)大講堂 ? 2024-06-22 08:11 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

一直覺得C語言較其他語言最偉大的地方就是C語言中的指針,有些人認(rèn)為指針很簡單,而有些人認(rèn)為指針很難,當(dāng)然這里的對簡單和難并不是等價(jià)于對指針的理解程度。為此在這里對C語言中的指針進(jìn)行全面的總結(jié),從底層的內(nèi)存分析,徹底讓大家明白指針的本質(zhì)。建議大家靜下心來再復(fù)習(xí)一遍。

一、指針變量

首先要明白指針是一個(gè)變量,為此寫了如下代碼來驗(yàn)證之:

edd7384c-302b-11ef-a655-92fbcf53809c.png

ede28ae4-302b-11ef-a655-92fbcf53809c.png

運(yùn)行后可以看到a的值被更改了,上面的例子可以清楚的明白指針實(shí)質(zhì)上是一個(gè)放置變量地址的特殊變量,其本質(zhì)仍然是變量。既然指針是變量,那必然會(huì)有變量類型,因此這里必須對變量類型做解釋。在C語言中,所有的變量都有變量類型,整型、浮現(xiàn)型、字符型、指針類型、結(jié)構(gòu)體、聯(lián)合體、枚舉等,這些都是變量類型。變量類型的出現(xiàn)是內(nèi)存管理的必然結(jié)果,相信讀者知道,所有的變量都是保存在計(jì)算機(jī)的內(nèi)存中,既然是放到計(jì)算機(jī)的內(nèi)存中,那必然會(huì)占用一定的空間。問題來了,一個(gè)變量會(huì)占用多少空間呢,或者說應(yīng)該分出多少內(nèi)存空間來放置該變量呢?為了規(guī)定這個(gè),類型由此誕生了,對于32位編譯器來說,int類型占用4個(gè)字節(jié),即32位,long類型占用8字節(jié),即64位。這里簡單說了類型主要是為后面引出指針這個(gè)特殊性,在計(jì)算機(jī)中,將要運(yùn)行的程序都保存在內(nèi)存中,所有的程序中的變量其實(shí)就是對內(nèi)存的操作。計(jì)算機(jī)的內(nèi)存結(jié)構(gòu)較為簡單,這里不詳細(xì)談?wù)搩?nèi)存的物理結(jié)構(gòu),只談?wù)搩?nèi)存模型。將計(jì)算機(jī)的內(nèi)存可以想象為一個(gè)房子,房子里面居住著人,每一個(gè)房間對應(yīng)著計(jì)算機(jī)的內(nèi)存地址,內(nèi)存中的數(shù)據(jù)就相當(dāng)于房子里的人。

edfd3a88-302b-11ef-a655-92fbcf53809c.png

既然指針也是一個(gè)變量,那個(gè)指針也應(yīng)該被存放在內(nèi)存中,對于32位編譯器來說,其尋址空間為2^32=4GB,為了能夠都操作所有內(nèi)存(實(shí)際上普通用戶不可能操作所有內(nèi)存),指針變量存放也要用32位數(shù)即4個(gè)字節(jié)。
這樣就有指針的地址&p,指針和變量的關(guān)系可以用如下圖表示:ee232a7c-302b-11ef-a655-92fbcf53809c.png

從上圖可以看到&p是指針的地址,用來存放指針p,而指針p來存放變量a的地址,也就是&a,還有一個(gè)*p在C語言中是解引,意思是告訴編譯器取出該地址存放的內(nèi)容。

ee3e2142-302b-11ef-a655-92fbcf53809c.png

上面提到過關(guān)于指針類型的問題,針對32位編譯器而言,既然任何指針都只占用4個(gè)字節(jié),那為何還需要引入指針類型呢?僅僅是為了約束相同類型的變量么?實(shí)際上這里不得不提到指針操作,先思考如下兩個(gè)操作:

ee5057e0-302b-11ef-a655-92fbcf53809c.png

上面兩個(gè)操作的意思是不同的,先說下第一種:p+1操作,如下圖所示:

ee541d58-302b-11ef-a655-92fbcf53809c.png

對于不同類型指針而言,其 p+1 所指向的地址不同,這個(gè)遞增取決于指針類型所占的內(nèi)存大小,而對于 ((unsigned int)p)+1。該意思是將地址 p 所指向的地址的值直接轉(zhuǎn)換為數(shù)字,然后 +1 ,這樣無論 p 是何種類型的指針,其結(jié)果都是指針?biāo)傅牡刂泛笠粋€(gè)地址。從上述可以看到,指針的存在使得程序員可以相當(dāng)輕松的操作內(nèi)存,這也使得當(dāng)前有些人認(rèn)為指針相當(dāng)危險(xiǎn),這一觀點(diǎn)表現(xiàn)在 C#Java 語言中,然而實(shí)際上用好指針可以極大的提高效率。
下面深入一點(diǎn)來通過指針對內(nèi)存進(jìn)行操作,現(xiàn)在我們需要對內(nèi)存6422216中填入一個(gè)數(shù)據(jù)125,我們可以如下操作:

ee69c72a-302b-11ef-a655-92fbcf53809c.png

當(dāng)然,上面的代碼使用了一個(gè)指針,實(shí)際上C語言中可以直接利用解引操作對內(nèi)存進(jìn)行更方便的賦值,下面說下解引操作*。

二、解引用

所謂解引操作,實(shí)際上是對一個(gè)地址操作,比如現(xiàn)在想將變量a進(jìn)行賦值,一般操作是a=125,現(xiàn)在我們用解引操作來完成,操作如下:

ee9adea0-302b-11ef-a655-92fbcf53809c.png

上面可以看到解引操作符為*,這個(gè)操作符對于指針有兩個(gè)不同的意義,當(dāng)在申明的時(shí)候是申明一個(gè)指針,而當(dāng)在使用p指針時(shí)是解引操作,解引操作右邊是一個(gè)地址,這樣解引操作的意思就是該地址內(nèi)存中的數(shù)據(jù)。這樣我們對內(nèi)存6422216中填入一個(gè)數(shù)據(jù)125就可以使用如下操作:

eeb77ac4-302b-11ef-a655-92fbcf53809c.png

上面需要將6422216數(shù)值強(qiáng)制轉(zhuǎn)換為一個(gè)地址,這個(gè)是告訴編譯器該數(shù)值是一個(gè)地址。值得注意的是上面的所有內(nèi)存地址不能隨便指定,必須是計(jì)算機(jī)已經(jīng)分配的內(nèi)存,否則計(jì)算機(jī)會(huì)認(rèn)為指針越界而被操作系統(tǒng)殺死即程序提前終止。

三、結(jié)構(gòu)體指針

結(jié)構(gòu)體指針和普通變量指針一樣,結(jié)構(gòu)體指針只占4個(gè)字節(jié)(32位編譯器),只不過結(jié)構(gòu)體指針可以很容易的訪問結(jié)構(gòu)體類型中的任何成員,這就是指針的成員運(yùn)算符->。

eedc871a-302b-11ef-a655-92fbcf53809c.png上圖中p是一個(gè)結(jié)構(gòu)體指針,p指向的是一個(gè)結(jié)構(gòu)體的首地址,而p->a可以用來訪問結(jié)構(gòu)體中的成員a,當(dāng)然p->a和*(p)是相同的。

四、強(qiáng)制類型轉(zhuǎn)換

為何要在這里提強(qiáng)制類型轉(zhuǎn)換呢,上面的測試代碼可以看到編譯器會(huì)報(bào)很多警告,意思是告訴程序員數(shù)據(jù)類型不匹配,雖然并不影響程序的正確運(yùn)行,但是很多警告總會(huì)讓人感到難受。因此為了告訴編譯器代碼這里沒有問題,程序員可以使用強(qiáng)制類型轉(zhuǎn)換來將一段內(nèi)存轉(zhuǎn)換為需要的數(shù)據(jù)類型,例如下面有一個(gè)數(shù)組a,現(xiàn)在將其強(qiáng)制轉(zhuǎn)換為一個(gè)結(jié)構(gòu)體類型stu:

ef1cef80-302b-11ef-a655-92fbcf53809c.png

上面的程序運(yùn)行結(jié)果如下:

ef3af6b0-302b-11ef-a655-92fbcf53809c.png

可以看到a[100]被強(qiáng)制轉(zhuǎn)換為stu結(jié)構(gòu)體類型,當(dāng)然不使用強(qiáng)制類型轉(zhuǎn)換也是可以的,只是編譯器會(huì)報(bào)警報(bào)。

ef4bab7c-302b-11ef-a655-92fbcf53809c.png

上圖為程序的示意圖,圖中數(shù)組a[100]的前12個(gè)字節(jié)被強(qiáng)制轉(zhuǎn)換為了一個(gè)struct stu類型,上面僅對數(shù)組進(jìn)行了說明,其它數(shù)據(jù)類型也是一樣的,本質(zhì)上都是一段內(nèi)存空間。

五、void指針

為何在這里單獨(dú)提到空指針類型呢?主要是因?yàn)樵撝羔橆愋秃芴厥狻?br />void類型很容易讓人想到是空的意思,但對于指針而言,其并不是指空,而是指不確定。
在很多時(shí)候指針在申明的時(shí)候可能并不知道是什么類型或者該指針指向的數(shù)據(jù)類型有多種再或者程序員僅僅是想通過一個(gè)指針來操作一段內(nèi)存空間。這個(gè)時(shí)候可以將指針申明為void類型。但是問題來了,由于void類型原因,對于確定的數(shù)據(jù)類型解引時(shí),編譯器會(huì)根據(jù)類型所占的空間來解引相應(yīng)的數(shù)據(jù),例如int p,那么p就會(huì)被編譯器解引為p指針的地址的4個(gè)字節(jié)的空間大小。
但對于空指針類型來說,編譯器如何知道其要解引的內(nèi)存大小呢?先看一段代碼:

ef7b18a8-302b-11ef-a655-92fbcf53809c.png

編譯上面的程序會(huì)發(fā)現(xiàn),編譯器報(bào)錯(cuò),無法正常編譯。

ef95ff2e-302b-11ef-a655-92fbcf53809c.png

這說明編譯器確實(shí)是在解引時(shí)無法確定*p的大小,因此這里必須告訴編譯器p的類型或者*p的大小,如何告訴呢?很簡單,用強(qiáng)制類型轉(zhuǎn)換即可,如下:

efe01726-302b-11ef-a655-92fbcf53809c.png

這樣上面的程序就可以寫為如下:

eff05b04-302b-11ef-a655-92fbcf53809c.png

編譯運(yùn)行后:

f0121730-302b-11ef-a655-92fbcf53809c.png

可以看到結(jié)果確實(shí)是正確的,也和預(yù)期的想法一致。由于void指針沒有空間大小屬性,因此void指針也沒有++操作。

f02c09c4-302b-11ef-a655-92fbcf53809c.png

六、函數(shù)指針

6.1 函數(shù)指針使用

函數(shù)指針在Linux內(nèi)核中用的非常多,而且在設(shè)計(jì)操作系統(tǒng)的時(shí)候也會(huì)用到,因此這里將詳細(xì)講解函數(shù)指針。既然函數(shù)指針也是指針,那函數(shù)指針也占用4個(gè)字節(jié)(32位編譯器)。
下面以一個(gè)簡單的例子說明:

f06b0d36-302b-11ef-a655-92fbcf53809c.png

程序運(yùn)行結(jié)果如下:

f07ad95a-302b-11ef-a655-92fbcf53809c.png

可以看到,函數(shù)指針的申明為:

f0a83580-302b-11ef-a655-92fbcf53809c.png

函數(shù)指針的解引操作與普通的指針有點(diǎn)不一樣。對于普通的指針而言,解引只需要根據(jù)類型來取出數(shù)據(jù)即可,但函數(shù)指針是要調(diào)用一個(gè)函數(shù),其解引不可能是將數(shù)據(jù)取出,實(shí)際上函數(shù)指針的解引本質(zhì)上是執(zhí)行函數(shù)的過程,只是這個(gè)執(zhí)行函數(shù)是使用的call指令并不是之前的函數(shù),而是函數(shù)指針的值,即函數(shù)的地址。
其實(shí)執(zhí)行函數(shù)的過程本質(zhì)上也是利用call指令來調(diào)用函數(shù)的地址,因此函數(shù)指針本質(zhì)上就是保存函數(shù)執(zhí)行過程的首地址。函數(shù)指針的調(diào)用如下:

f0c9aee0-302b-11ef-a655-92fbcf53809c.png

為了確認(rèn)函數(shù)指針本質(zhì)上是傳遞給call指令一個(gè)函數(shù)的地址,下面用一個(gè)簡單例子說明:

f0e940e8-302b-11ef-a655-92fbcf53809c.png

上面是編譯后的匯編指令,可以看到,使用函數(shù)指針來調(diào)用函數(shù)時(shí),其匯編指令多了如下:

f10b2f28-302b-11ef-a655-92fbcf53809c.png

分析:第一行mov指令將立即數(shù)0x4015c0賦值給寄存器esp+0xc的地址內(nèi)存中,然后將寄存器esp+0xc地址的值賦值給寄存器eax(累加器),然后調(diào)用call指令,此時(shí)pc指針將會(huì)指向add函數(shù),而0x4015c0正好是函數(shù)add的首地址,這樣就完成了函數(shù)的調(diào)用。細(xì)心的讀者是否發(fā)現(xiàn)一個(gè)有趣的現(xiàn)象,上述過程中函數(shù)指針的值和參數(shù)一樣是被放在棧幀中,這樣看起來就是一個(gè)參數(shù)傳遞的過程。因此可以看到,函數(shù)指針最終還是以參數(shù)傳遞的形式傳遞給被調(diào)用的函數(shù),而這個(gè)傳遞的值正好是函數(shù)的首地址。從上面可以看到函數(shù)指針并不是和一般的指針一樣可以操作內(nèi)存,因此作者覺得函數(shù)指針可以看作是函數(shù)的引用申明。

6.2 函數(shù)指針應(yīng)用

在linux驅(qū)動(dòng)面向?qū)ο?a target="_blank">編程思想中用的最多,利用函數(shù)指針來實(shí)現(xiàn)封裝,下面以一個(gè)簡單的例子說明:

#include

typedefstructTFT_DISPLAY
{
intpix_width;
intpix_height;
intcolor_width;
void(*init)(void);
void(*fill_screen)(intcolor);
void(*tft_test)(void);

}tft_display;

staticvoidinit(void)
{
printf("thedisplayisinitialed\n");
}

staticvoidfill_screen(intcolor)
{
printf("thedisplayscreenset0x%x\n",color);

}

tft_displaymydisplay=
{
.pix_width=320,
.pix_height=240,
.color_width=24,
.init=init,
.fill_screen=fill_screen,
};

intmain(intargc,char**argv)
{

mydisplay.init();
mydisplay.fill_screen(0xfff);
return0;
}

上面的例子將一個(gè)tft_display封裝成一個(gè)對象,上面的結(jié)構(gòu)體成員中最后一個(gè)沒有初始化,這在Linux中用的非常多。最常見的是file_operations結(jié)構(gòu)體,該結(jié)構(gòu)體一般來說只需要初始化常見的函數(shù),不需要全部初始化。
上面代碼中采用的結(jié)構(gòu)體初始化方式也是在Linux中最常用的一種方式,這種方式的好處在于無需按照結(jié)構(gòu)體的順序一對一。

6.3 回調(diào)函數(shù)

有時(shí)候會(huì)遇到這樣一種情況,當(dāng)上層人員將一個(gè)功能交給下層程序員完成時(shí),上層程序員和下層程序員同步工作,這個(gè)時(shí)候該功能函數(shù)并未完成,這個(gè)時(shí)候上層程序員可以定義一個(gè)API來交給下層程序員。而上層程序員只要關(guān)心該API就可以了而無需關(guān)心具體實(shí)現(xiàn),具體實(shí)現(xiàn)交給下層程序員完成即可(這里的上層和下層程序員不指等級關(guān)系,而是項(xiàng)目的分工關(guān)系)。
這種情況下就會(huì)用到回調(diào)函數(shù)(Callback Function),現(xiàn)在假設(shè)程序員A需要一個(gè)FFT算法,這個(gè)時(shí)候程序員A將FFT算法交給程序員B來完成,現(xiàn)在來讓實(shí)現(xiàn)這個(gè)過程:

#include

intInputData[100]={0};
intOutputData[100]={0};

voidFFT_Function(int*inputData,int*outputData,intnum)
{
while(num--)
{

}
}

voidTaskA_CallBack(void(*fft)(int*,int*,int))
{

(*fft)(InputData,OutputData,100);
}

intmain(intargc,char**argv)
{

TaskA_CallBack(FFT_Function);
return0;
}

上面的代碼中TaskA_CallBack是回調(diào)函數(shù),該函數(shù)的形參為一個(gè)函數(shù)指針,而FFT_Function是一個(gè)被調(diào)用函數(shù)。

可以看到回調(diào)函數(shù)中申明的函數(shù)指針必須和被調(diào)用函數(shù)的類型完全相同。

本文轉(zhuǎn)載自公眾號|芯片之家如有侵權(quán) |聯(lián)系刪除

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • C語言
    +關(guān)注

    關(guān)注

    180

    文章

    7632

    瀏覽量

    141720
  • 函數(shù)指針
    +關(guān)注

    關(guān)注

    2

    文章

    57

    瀏覽量

    3975
  • 指針函數(shù)
    +關(guān)注

    關(guān)注

    0

    文章

    10

    瀏覽量

    2889
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點(diǎn)推薦

    函數(shù)指針的使用簡述

    函數(shù)指針在Linux內(nèi)核和C語言開發(fā)中用的非常多,而且在設(shè)計(jì)操作系統(tǒng)的時(shí)候也會(huì)用到,因此這里將詳細(xì)講解函數(shù)指針。既然函數(shù)
    的頭像 發(fā)表于 09-09 08:56 ?2290次閱讀
    <b class='flag-5'>函數(shù)</b><b class='flag-5'>指針</b>的使用簡述

    函數(shù)指針指針函數(shù)的概念

    不少朋友會(huì)混淆“函數(shù)指針”和“指針函數(shù)”這兩個(gè)概念,本文詳細(xì)介紹一下。
    發(fā)表于 03-09 10:49 ?1455次閱讀

    C語言中指針函數(shù)函數(shù)指針的概念及應(yīng)用示例

    在C語言中,指針函數(shù)函數(shù)指針是強(qiáng)大且常用的工具。它們允許我們以更靈活的方式處理函數(shù)和數(shù)據(jù),進(jìn)而擴(kuò)展程序的功能。
    發(fā)表于 08-16 16:14 ?1582次閱讀

    一文詳解函數(shù)指針與回調(diào)函數(shù)

    函數(shù)指針是指向函數(shù)指針變量。它允許我們將函數(shù)作為參數(shù)傳遞給其他函數(shù)或?qū)?/div>
    發(fā)表于 08-22 10:36 ?710次閱讀

    函數(shù)指針指針函數(shù)定義

    函數(shù)指針指針函數(shù),C語言學(xué)習(xí)中最容易混淆的一些概念,好好學(xué)習(xí)吧
    發(fā)表于 01-11 16:44 ?0次下載

    C語言指針函數(shù)函數(shù)指針詳細(xì)介紹

    C語言指針函數(shù)函數(shù)指針詳細(xì)介紹。。。。。。。
    發(fā)表于 03-04 15:27 ?5次下載

    c語言函數(shù)指針定義,指針函數(shù)函數(shù)指針的區(qū)別

     往往,我們一提到指針函數(shù)函數(shù)指針的時(shí)候,就有很多人弄不懂。下面就由小編詳細(xì)為大家介紹C語言中函數(shù)指針
    發(fā)表于 11-16 15:18 ?3870次閱讀

    ARM的函數(shù)指針、指針函數(shù)的區(qū)別和用法

    在學(xué)習(xí)arm過程中發(fā)現(xiàn)這“指針函數(shù)”與“函數(shù)指針”容易搞錯(cuò),所以今天,我自己想一次把它搞清楚,找了一些資料,和大家的一些總結(jié),整理到此。和大家分享。
    的頭像 發(fā)表于 06-20 10:08 ?3783次閱讀

    理解函數(shù)指針函數(shù)指針數(shù)組、函數(shù)指針數(shù)組的指針

    理解函數(shù)指針函數(shù)指針數(shù)組、函數(shù)指針數(shù)組的指針
    的頭像 發(fā)表于 06-29 15:38 ?1.5w次閱讀
    理解<b class='flag-5'>函數(shù)</b><b class='flag-5'>指針</b>、<b class='flag-5'>函數(shù)</b><b class='flag-5'>指針</b>數(shù)組、<b class='flag-5'>函數(shù)</b><b class='flag-5'>指針</b>數(shù)組的<b class='flag-5'>指針</b>

    C語言-內(nèi)聯(lián)函數(shù)、遞歸函數(shù)指針函數(shù)

    這篇文章介紹C語言的內(nèi)聯(lián)函數(shù)、遞歸函數(shù)、函數(shù)指針、指針函數(shù)、局部地址、const關(guān)鍵字、exte
    的頭像 發(fā)表于 08-14 10:03 ?2000次閱讀

    指針進(jìn)階第五站:函數(shù)指針

    定義一個(gè)函數(shù)指針,指向的函數(shù)有兩個(gè)int形參并且返回一個(gè)函數(shù)指針,返回的指針指向一個(gè)有一個(gè)int
    發(fā)表于 08-17 15:58 ?664次閱讀

    如何使用函數(shù)指針

    在程序定義一個(gè)函數(shù),則編譯時(shí)系統(tǒng)就會(huì)為這段代碼分配一段存儲空間,這段存儲空間的首地址稱為函數(shù)的地址,且函數(shù)名代表的就是這個(gè)地址。既然是地址就可以使用一個(gè)
    的頭像 發(fā)表于 03-30 15:09 ?1095次閱讀

    函數(shù)指針指針函數(shù)是不是一個(gè)東西?

    函數(shù)指針的本質(zhì)是指針,就跟整型指針、字符指針一樣,函數(shù)指針
    的頭像 發(fā)表于 01-03 16:35 ?772次閱讀
    <b class='flag-5'>函數(shù)</b><b class='flag-5'>指針</b>和<b class='flag-5'>指針</b><b class='flag-5'>函數(shù)</b>是不是一個(gè)東西?

    函數(shù)指針與回調(diào)函數(shù)的應(yīng)用實(shí)例

    通常我們說的指針變量是指向一個(gè)整型、字符型或數(shù)組等變量,而函數(shù)指針是指向函數(shù)。 函數(shù)指針
    的頭像 發(fā)表于 03-07 11:13 ?630次閱讀
    <b class='flag-5'>函數(shù)</b><b class='flag-5'>指針</b>與回調(diào)<b class='flag-5'>函數(shù)</b>的應(yīng)用實(shí)例

    面試???1:函數(shù)指針指針函數(shù)、數(shù)組指針指針數(shù)組

    在嵌入式開發(fā)領(lǐng)域,函數(shù)指針、指針函數(shù)、數(shù)組指針指針數(shù)組是一些非常重要但又容易混淆的概念。理解它
    的頭像 發(fā)表于 08-10 08:11 ?1455次閱讀
    <b class='flag-5'>面試</b>???1:<b class='flag-5'>函數(shù)</b><b class='flag-5'>指針</b>與<b class='flag-5'>指針</b><b class='flag-5'>函數(shù)</b>、數(shù)組<b class='flag-5'>指針</b>與<b class='flag-5'>指針</b>數(shù)組