• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            一、指針函數
                
            當一個函數聲明其返回值為一個指針時,實際上就是返回一個地址給調用函數,以用于需要指針或地址的表達式中。
                
            格式:
                     
            類型說明符 * 函數名(參數)
                
            當然了,由于返回的是一個地址,所以類型說明符一般都是int
                
            例如:int *GetDate();
                      int * aaa(int,int);
                
            函數返回的是一個地址值,經常使用在返回數組的某一元素地址上。

                    int * GetDate(int wk,int dy);

                    main()
                    {
                        int wk,dy;
                        do
                        {
                            printf("Enter week(1-5)day(1-7)\n");
                            scanf("%d%d",&wk,&dy);
                        }
                        while(wk<1||wk>5||dy<1||dy>7);
                        printf("%d\n",*GetDate(wk,dy));
                    }

                    int * GetDate(int wk,int dy)
                    {
                        static int calendar[5][7]=
                        {
                           {1,2,3,4,5,6,7},
                           {8,9,10,11,12,13,14},
                           {15,16,17,18,19,20,21},
                           {22,23,24,25,26,27,28},
                           {29,30,31,-1}
                        };
                        return &calendar[wk-1][dy-1];
                    }
                    
            程序應該是很好理解的,子函數返回的是數組某元素的地址。輸出的是這個地址里的值。

            二、函數指針
                
            指向函數的指針包含了函數的地址,可以通過它來調用函數。聲明格式如下:
                    
            類型說明符 (*函數名)(參數)
                
            其實這里不能稱為函數名,應該叫做指針的變量名。這個特殊的指針指向一個返回整型值的函數。指針的聲明筆削和它指向函數的聲明保持一致。
                    
            指針名和指針運算符外面的括號改變了默認的運算符優先級。如果沒有圓括號,就變成了一個返回整型指針的函數的原型聲明。
                
            例如:
                    void (*fptr)();
                
            把函數的地址賦值給函數指針,可以采用下面兩種形式:
                    fptr=&Function;
                    fptr=Function;
                
            取地址運算符&不是必需的,因為單單一個函數標識符就標號表示了它的地址,如果是函數調用,還必須包含一個圓括號括起來的參數表。
                
            可以采用如下兩種方式來通過指針調用函數:
                    x=(*fptr)();
                    x=fptr();
                
            第二種格式看上去和函數調用無異。但是有些程序員傾向于使用第一種格式,因為它明確指出是通過指針而非函數名來調用函數的。下面舉一個例子:

                    void (*funcp)();
                    void FileFunc(),EditFunc();

                    main()
                    {
                        funcp=FileFunc;
                        (*funcp)();
                        funcp=EditFunc;
                        (*funcp)();
                    }

                    void FileFunc()
                    {
                        printf("FileFunc\n");
                    }

                    void EditFunc()
                    {
                        printf("EditFunc\n");
                    }

                    
            程序輸出為:
                        FileFunc
                        EditFunc

            三、指針的指針
                
            指針的指針看上去有些令人費解。它們的聲明有兩個星號。例如:
                    char ** cp;
                
            如果有三個星號,那就是指針的指針的指針,四個星號就是指針的指針的指針的指針,依次類推。當你熟悉了簡單的例子以后,就可以應付復雜的情況了。當然,實際程序中,一般也只用到二級指針,三個星號不常見,更別說四個星號了。
                
            指針的指針需要用到指針的地址。
                    char c='A';
                    char *p=&c;
                    char **cp=&p;
                
            通過指針的指針,不僅可以訪問它指向的指針,還可以訪問它指向的指針所指向的數據。下面就是幾個這樣的例子:
                    char *p1=*cp;
                    char c1=**cp;
                
            你可能想知道這樣的結構有什么用。利用指針的指針可以允許被調用函數修改局部指針變量和處理指針數組。

                    void FindCredit(int **);

                    main()
                    {
                        int vals[]={7,6,5,-4,3,2,1,0};
                        int *fp=vals;
                        FindCredit(&fp);
                        printf("%d\n",*fp);
                    }

                    void FindCredit(int ** fpp)
                    {
                        while(**fpp!=0)
                        if(**fpp<0) break;
                        else (*fpp)++;
                    }

                
            首先用一個數組的地址初始化指針fp,然后把該指針的地址作為實參傳遞給函數FindCredit()FindCredit()函數通過表達式**fpp間接地得到數組中的數據。為遍歷數組以找到一個負值,FindCredit()函數進行自增運算的對象是調用者的指向數組的指針,而不是它自己的指向調用者指針的指針。語句(*fpp)++就是對形參指針指向的指針進行自增運算的。但是因為*運算符高于++運算符,所以圓括號在這里是必須的,如果沒有圓括號,那么++運算符將作用于二重指針fpp上。

            四、指向指針數組的指針
                
            指針的指針另一用法舊處理指針數組。有些程序員喜歡用指針數組來代替多維數組,一個常見的用法就是處理字符串。

                    char *Names[]=
                    {
                         "Bill",
                         "Sam",
                         "Jim",
                         "Paul",
                         "Charles",
                         0
                    };

                    main()
                    {
                        char **nm=Names;
                        while(*nm!=0) printf("%s\n",*nm++);
                    }

                
            先用字符型指針數組Names的地址來初始化指針nm。每次printf()的調用都首先傳遞指針nm指向的字符型指針,然后對nm進行自增運算使其指向數組的下一個元素(還是指針)。注意完成上述認為的語法為*nm++,它首先取得指針指向的內容,然后使指針自增。
                
            注意數組中的最后一個元素被初始化為0,while循環以次來判斷是否到了數組末尾。具有零值的指針常常被用做循環數組的終止符。程序員稱零值指針為空指針(NULL)。采用空指針作為終止符,在樹種增刪元素時,就不必改動遍歷數組的代碼,因為此時數組仍然以空指針作為結束。
            Posted on 2005-11-03 11:26 艾凡赫 閱讀(4161) 評論(0)  編輯 收藏 引用 所屬分類: 數據類型
            久久久久高潮毛片免费全部播放 | 中文字幕无码久久人妻| 久久这里都是精品| 91精品日韩人妻无码久久不卡| 亚州日韩精品专区久久久| 国产综合成人久久大片91| 91精品国产91久久久久福利 | 久久精品国产99久久无毒不卡 | 欧美久久亚洲精品| 人妻无码久久精品| 99999久久久久久亚洲| 久久亚洲中文字幕精品一区四| 无码国内精品久久综合88 | 国产亚洲精品久久久久秋霞| 久久最近最新中文字幕大全| 国产精品免费久久| 久久精品国产亚洲AV蜜臀色欲 | 久久精品中文字幕一区| 久久av无码专区亚洲av桃花岛| 色综合合久久天天给综看| 久久狠狠高潮亚洲精品| 久久涩综合| 中文字幕亚洲综合久久2| 国产成人无码精品久久久免费| AAA级久久久精品无码区| 久久久WWW成人免费精品| 久久国产一区二区| 青青青国产精品国产精品久久久久 | 久久这里的只有是精品23| 久久99国产精品久久| 99999久久久久久亚洲| 奇米影视7777久久精品| 国产精品成人久久久| 国产精品久久99| 人妻丰满AV无码久久不卡| 亚洲国产精品人久久| 狠狠88综合久久久久综合网| 99精品久久精品一区二区| 国产69精品久久久久9999APGF| 亚洲综合伊人久久综合| 老司机国内精品久久久久|