• <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)  編輯 收藏 引用 所屬分類: 數據類型
            无码任你躁久久久久久| 久久成人影院精品777| 欧美成人免费观看久久| 狠狠综合久久综合88亚洲| 久久国产精品77777| 久久久久综合国产欧美一区二区 | 亚洲精品乱码久久久久久蜜桃| 亚洲欧洲久久av| 97超级碰碰碰碰久久久久| 国产成人综合久久精品红| 欧美激情精品久久久久| 久久午夜福利无码1000合集| 2020最新久久久视精品爱| 亚洲AV无一区二区三区久久| 精品国产婷婷久久久| 国产精品9999久久久久| 久久人与动人物a级毛片| 久久青青草原亚洲av无码| 精品亚洲综合久久中文字幕| 伊人久久大香线蕉综合Av| 婷婷久久精品国产| 久久99精品国产99久久6| 国内精品久久久久久野外| 亚洲av成人无码久久精品 | 久久精品成人免费网站| 久久超碰97人人做人人爱| 午夜精品久久久久久久久| 伊人色综合久久天天人守人婷| 99久久精品国产一区二区| 69久久精品无码一区二区| 欧美一区二区三区久久综| 亚洲精品乱码久久久久久久久久久久 | 久久久久久精品无码人妻| 一级做a爰片久久毛片看看| 久久影院久久香蕉国产线看观看| 久久久久无码国产精品不卡| 久久精品国产亚洲Aⅴ香蕉| 开心久久婷婷综合中文字幕| 久久99热这里只有精品66| 人妻久久久一区二区三区| 高清免费久久午夜精品|