void point(char *p){ p+=3; } //加上void比較好
成都創(chuàng)新互聯(lián)始終堅持【策劃先行,效果至上】的經(jīng)營理念,通過多達10多年累計超上千家客戶的網(wǎng)站建設(shè)總結(jié)了一套系統(tǒng)有效的營銷解決方案,現(xiàn)已廣泛運用于各行各業(yè)的客戶,其中包括:成都輕質(zhì)隔墻板等企業(yè),備受客戶稱揚。
char b[4]={'a','b','c','d'}, *p=b; //寫在同一行,p是char*的
point(p);// 這里傳遞的是指針,在函數(shù)里面改指針是“臨時變量”,不是局部變量
//臨時對象不會被記錄,如果改p指向的內(nèi)存就可以被記錄。
printf("%c\n", *p); // 輸出結(jié)果為a,因為p是扔指向b[]其實位置
答案為a
整個程序的目的是對一組數(shù)據(jù)進行求最大值、最小值或平均值的操作,通過輸入的指令進行相應(yīng)的操作。按照不用函數(shù)指針的思路,程序大概會寫成這樣:(以下為偽代碼)
最大值函數(shù){...}
最小值函數(shù){...}
平均值函數(shù){...}
main{
輸入d,則調(diào)用 最大值函數(shù)
輸入x,則調(diào)用 最小值函數(shù)
輸入p,則調(diào)用平均值函數(shù)
}
不過可以發(fā)現(xiàn)如下幾點:
· 三個函數(shù)的參數(shù)形式與返回值都是完全一樣的
· 按上述方法寫代碼,每次調(diào)用都要寫清楚參數(shù),略顯啰嗦
所以就使用函數(shù)指針來重新改寫代碼
GetOperation這個函數(shù)本身,就是根據(jù)輸入指令找到對應(yīng)的 操作函數(shù)并作為函數(shù)指針返回它,然后main里直接通過函數(shù)指針調(diào)用,調(diào)用代碼只需要寫一次,而且甚至不用關(guān)心這個函數(shù)指針代表的到底是哪個函數(shù)
這個程序里只有三個對數(shù)據(jù)的操作所以函數(shù)指針的優(yōu)點不是很明顯。假設(shè)有多大100種對數(shù)據(jù)的操作,如果不使用函數(shù)指針,就要不停地寫if else if else if...,使用函數(shù)指針,甚至可以事先建立一個指令字符與操作函數(shù)指針的對應(yīng)列表,運行時直接在列表里搜索抽取,代碼就顯得干凈利索
GetOperation(c)(dbData,iSize)這句話的具體執(zhí)行操作是:
(下面假設(shè)輸入了c='d')
首先執(zhí)行GetOperation('d'),該函數(shù)返回得到GetMax(的指針),再執(zhí)行GetMax(bData,iSize),即對數(shù)據(jù)求最大值的操作,函數(shù)返回得到最大值
并不是不規(guī)范的問題,你子程序?qū)懛ㄖ荒茉谧映绦蛑休敵稣_的數(shù)據(jù),而在主函數(shù)中無法得到交換過的x和y的值。參考程序運用指針讓子程序去讀寫a和b的值,在子程序執(zhí)行完成后,a和b的值確實得到了交換。
你的程序中子程序采用的不是指針類型參數(shù),這樣子程序無法將交換過后的值傳回來。
有函數(shù): int fun(int a,int b);
要定義指向該函數(shù)的指針
對比指向 int a; 的指針
int *p; p = a;
p的定義是怎么來的?
首先要保證p是一個指針類型
寫下(*p),
然后,考慮下p的基類型,
p的基類型就是變量a的類型int
將int 放在(*p)前面就行了
int (*p);
括號可以省略,就成了 int *p;
同理
想要實現(xiàn) pf = fun;
(*pf) 將pf定義為一個指針,
將fun的類型作為pf的基類型
fun相當(dāng)于一個 int (int a,int b)類型的量
int (int a,int b) (*pf);
基類型中有圓括號和中括號要后移
int (*pf)(int a,int b) ;//括號不能省略
pf = fun;
調(diào)用時
(*pf)(3,4); pf(3,4)都可以
在程序運行時,一個函數(shù)占用一段連續(xù)的內(nèi)存。當(dāng)調(diào)用一個函數(shù)時,實際上是跳轉(zhuǎn)到函數(shù)的入口地址,執(zhí)行函數(shù)體的代碼,完成后返回。
函數(shù)指針指向一個函數(shù)的入口地址,也就是函數(shù)存儲空間的首地址。
在C語言中,數(shù)組名代表數(shù)組的首地址,同樣函數(shù)名代表了函數(shù)的首地址,因此在賦值時,直接將函數(shù)指針指向函數(shù)名就行了。
因此函數(shù)指針調(diào)用vs直接調(diào)用,占用的存儲空間都是一樣的。相當(dāng)于數(shù)組指針和數(shù)組名的關(guān)系,指向的都是同一個數(shù)組。
局部變量存在函數(shù)體里面,比如轉(zhuǎn)換成8086匯編(示意):
func: 定義變量
push ax
pop ax
ret
main: call func
滿意請采納,謝謝!
#includestdio.h
int *d_bubblesort(int a[],int n)//數(shù)組長度為n的冒泡降序排序
{
int i,j;
int temp;
for(i=0;in;i++)
{
for(j=n-1;ji;j--)
{
if(a[j]a[j-1])
{
temp=a[j-1];
a[j-1]=a[j];
a[j]=temp;
}
}
}
return a;
}
void main()
{
int i;
int *p=NULL;
int a[10]={6,5,4,1,2,3,9,8,7,10};
int *(*fun)(int*,int);
fun=d_bubblesort;
p=fun(a,10);
for(i=0;i10;i++)
{
printf("%d\t",p[i]);
}
}