資料**於網上:
一、指標函式:指返回值是指標的函式
型別識別符號 *函式名(參數列)
int *f(x,y);
首先它是乙個函式,只不過這個函式的返回值是乙個位址值。函式返回值必須用同型別的指標變數來接受,也就是說,指標函式一定有函式返回值,而且,在主調函式中,函式返回值必須賦給同型別的指標變數。
注意指標函式與函式指標表示方法的不同,千萬不要混淆。最簡單的辨別方式就是看函式名前面的指標*號有沒有被括號()包含,如果被包含就是函式指標,反之則是指標函式。
例如:int *getdate();
int * aaa(int,int);
函式返回的是乙個位址值,經常使用在返回陣列的某一元素位址上。不過返回位址有什麼用途呢??
int * getdate(int wk,int dy);
main() //沒看懂,也不是偽**呀
while(wk<1||wk>5||dy<1||dy>7);
printf(%d\n,*getdate(wk,dy));
}int * getdate(int wk,int dy),,
,,};return &calendar[wk-1][dy-1];
}子函式返回的是陣列某元素的位址。輸出的是這個位址裡的值。
二、函式指標:是指指向函式的指標變數,本質是乙個指標變數。
int (*f) (int x); 宣告乙個指標變數 /* 宣告乙個函式指標 */
f=func; f這個指標變數指向了func函式 /* 將func函式的首位址賦給指標f */
指向函式的指標包含了函式的位址,可以通過它來呼叫函式。宣告格式如下:
型別說明符 (*函式名)(引數) //這個引數的用途沒有看到啊,這個是返回值
其實這裡不能稱為函式名,應該叫做指標的變數名。這個特殊的指標指向乙個返回整型值的函式。指標的宣告必須和它指向函式的宣告保持一致。
指標名和指標運算子外面的括號改變了預設的運算子優先順序。如果沒有圓括號,就變成了乙個返回整型指標的函式的原型宣告。
例如:void (*fptr)();
把函式的位址賦值給函式指標,可以採用下面兩種形式:
fptr=&function;
fptr=function;
取位址運算子&不是必需的,因為單單乙個函式識別符號就標號表示了它的位址,如果是函式呼叫,還必須包含乙個圓括號括起來的參數列。
可以採用如下兩種方式來通過指標呼叫函式:
x=(*fptr)();
x=fptr();
第二種格式看上去和函式呼叫無異。但是有些程式設計師傾向於使用第一種格式,因為它明確指出是通過指標而非函式名來呼叫函式的。下面舉乙個例子:
void (*funcp)();
void filefunc(),editfunc();
main()
void filefunc()
void editfunc()
程式輸出為:
filefunc
editfunc
函式指標與指標函式,主要的區別是乙個是指標變數,乙個是函式。在使用是必要要搞清楚才能正確使用
二、指標的指標
指標的指標看上去有些令人費解。它們的宣告有兩個星號。例如:
char ** cp;
如果有三個星號,那就是指標的指標的指標,四個星號就是指標的指標的指標的指標,依次類推。當你熟悉了簡單的例子以後,就可以應付複雜的情況了。當然,實際程式中,一般也只用到 二級指標,三個星號不常見,更別說四個星號了。
指標的指標需要用到指標的位址。
char c='a';
char *p=&c;
char **cp=&p;
通過指標的指標,不僅可以訪問它指向的指標,還可以訪問它指向的指標所指向的資料。下面就是幾個這樣的例子:
char *p1=*cp;
char c1=**cp;
你可能想知道這樣的結構有什麼用。利用指標的指標可以允許被呼叫函式修改區域性指標變數和處理指標陣列。
void findcredit(int **);
main()
;int *fp=vals;
findcredit(&fp);
printf(%d\n,*fp);
}void findcredit(int ** fpp)
首先用乙個陣列的位址初始化指標fp,然後把該指標的位址作為實參傳遞給函式findcredit()。findcredit()函式通過表示式**fpp間接地得到陣列中的資料。為遍歷陣列以找到乙個負值,findcredit()函式進行自增運算的物件是呼叫者的指向陣列的指標,而不是它自己的指向呼叫者指標的指標。語句(*fpp)++就是對形參指標指向的指標進行自增運算的。但是因為*運算子高於++運算子,所以圓括號在這裡是必須的,如果沒有圓括號,那麼++運算子將作用於二重指標fpp上。
三、指向指標陣列的指標
指標的指標另一用法舊處理指標陣列。有些程式設計師喜歡用指標陣列來代替多維陣列,乙個常見的用法就是處理字串。
char *names=
;main()
先用字元型指標陣列names的位址來初始化指標nm。每次printf()的呼叫都首先傳遞指標nm指向的字元型指標,然後對nm進行自增運算使其指向陣列的下乙個元素(還是指標)。注意完成上述認為的語法為*nm++,它首先取得指標指向的內容,然後使指標自增。
注意陣列中的最後乙個元素被初始化為0,while迴圈以次來判斷是否到了陣列末尾。具有零值的指標常常被用做迴圈陣列的終止符。程式設計師稱零值指標為空指標(null)。採用空指標作為終止符,在樹種增刪元素時,就不必改動遍歷陣列的**,因為此時陣列仍然以空指標作為結束。
C語言 指標陣列和指標陣列 函式指標和指標函式
在c語言中最令然頭疼的莫過於指標 特別是指標和陣列符號一起出現的 傻傻搞不清楚的原因主要在於運算子的優先順序沒有搞清 指標的運算子 陣列運算子,函式運算子 陣列元算符 運算優先順序和函式運算子 或者說強制改變運算順序符號 都是位於第一優先順序的 而我們的指標運算子則是第二優先順序 所以當出現 int...
c語言函式指標與指標函式
include include include using namespace std 1 c語言函式指標 解釋 這是一種很特殊的指標,它的指向是乙個函式的入口 作用 該指標可以接受乙個函式的位址,代表這個函式執行函式的操作 函式指標舉例 下面是乙個函式指標pfunc,它只能指向返回值為float,...
C語言函式指標與指標函式
在大家剛開始學習c語言的時候,總是分不清函式指標和指標函式,就算是知道了它們之間的區別,也不了解它們的使用場景,我寫此部落格幫大家縷一縷,也幫我自己縷一縷 1 函式指標與指標函式的概念以及區別 指標函式 從名字上可以看出,首先它是乙個函式,指標指的是返回值為指標 函式指標 從名字上可以看出,首先他是...