二級指標,指向指標的指標

2021-05-25 09:36:23 字數 1556 閱讀 7055

test 函式的語句getmemory(str, 200)並沒有使str 獲得期望的記憶體,str 依舊是null,為什麼?

//指標傳遞

void getmemory(char *p, int num)

void test(void)

//解釋

毛病出在函式getmemory 中,編譯器總是要為函式的每個引數製作臨時副本,指標引數p 的副本是 _p,編譯器使 _p = p。如果函式體內的程式修改了_p 的內容,就導致引數p 的內容作相應的修改。這就是指標可以用作輸出引數的原因。在本例中,_p 申請了新的記憶體,只是把_p 所指的記憶體位址改變了,但是p 絲毫未變。所以函式getmemory並不能輸出任何東西。事實上,每執行一次getmemory 就會洩露一塊記憶體,因為沒有用

free 釋放記憶體。

c語言規定main函式的引數只能有兩個,習慣上這兩個引數寫為argc和argv。因此,main函式的函式頭可寫為:

main (argc,argv)

c語言還規定argc(第乙個形參)必須是整型變數,argv( 第二個形參)必須是指向字串的指標陣列。加上形參說明後,main函式的函式頭應寫為:

main (int argc,char *argv)

由於main函式不能被其它函式呼叫,因此不可能在程式內部取得實際值。那麼,在何處把實參值賦予main函式的形參呢? 實際上,main函式的引數值是從作業系統命令列上獲得的。當我們要執行乙個可執行檔案時,在dos提示符下鍵入檔名,再輸入實際引數即可把這些實參傳送到main的形參中去。

dos提示符下命令列的一般形式為:

c:/>

可執行檔名

引數引數……;

但是應該特別注意的是,main 的兩個形參和命令列中的引數在位置上不是一一對應的。因為,main的形參只有二個,而命令列中的引數個數原則上未加限制。argc引數表示了命令列中引數的個數(注意:檔名本身也算乙個引數),argc的值是在輸入命令行時由系統按實際引數的個數自動賦予的。

例如有命令行為:

c:/>e24basicfoxprofortran

由於檔名e24本身也算乙個引數,所以共有4個引數,因此argc取得的值為4。argv引數是字串指標陣列,其各元素值為命令列中各字串(引數均按字串處理)的首位址。指標陣列的長度即為引數個數。陣列元素初值由系統自動賦予。

【例10.38】

main(int argc,char *argv)

本例是顯示命令列中輸入的引數。如果上例的可執行檔名為e24.exe,存放在a驅動器的盤內。因此輸入的命令行為:

c:/>a:e24 basic foxpro fortran

則執行結果為:

basic

foxpro

fortran

該行共有4個引數,執行main時,argc的初值即為4。argv的4個元素分為4個字串的首位址。執行while語句,每迴圈一次argv值減1,當argv等於1時停止迴圈,共迴圈三次,因此共可輸出三個引數。在printf函式中,由於列印項*++argv是先加1再列印,故第一次列印的是argv[1]所指的字串basic。第

二、三次迴圈分別列印後二個字串。而引數e24是檔名,不必輸出。

二級指標,指向指標的指標

我們先來看乙個例子 假設我們有第三個變數時 c b c的型別顯然是乙個指標,變數b是乙個 指向整形的指標 所以任何指向b的型別必須是指向 指向的指標 的指標,更通俗的來講就是指標的指標。它合法嗎?指標變數和其他變數一樣,佔據記憶體中某個特定的位置,所以用 操作符取得他的位址是合法的。這個變數宣告為 ...

二級指標(指向指標的指標)

指標可以指向乙份普通型別的資料,例如 int double char 等,也可以指向乙份指標型別的資料,例如 int double char 等。如果乙個指標指向的是另外乙個指標,我們就稱它為二級指標,或者指向指標的指標。假設有乙個 int 型別的變數 a,p1是指向 a 的指標變數,p2 又是指向...

C語言 二級指標(指向指標的指標)詳解

摘自 c語言入門 指標可以指向乙份普通型別的資料,例如 int double char 等,也可以指向乙份指標型別的資料,例如 int double char 等。如果乙個指標指向的是另外乙個指標,我們就稱它為二級指標,或者指向指標的指標。假設有乙個 int 型別的變數 a,p1是指向 a 的指標變...