回调函数是一个程序员不能显式调用的函数;通过将回调函数的地址传给调用者从而实现调用。回调函数使用是必要的,在我们想通过一个统一接口实现不同的内容,这时用回掉函数非常合适。比如,我们为几个不同的设备分别写了不同的显示函数:void TVshow(); void ComputerShow(); void NoteBookShow()…等等。这是我们想用一个统一的显示函数,我们这时就可以用回掉函数了。void show(void (*ptr)());使用时根据所传入的参数不同而调用不同的回调函数。不同的编程语言可能有不同的语法,下面举一个c语言中回调函数的例子,其中一个回调函数不带参数,另一个回调函数带参数。
例子1:
//Test.c
#include
#include
int Test1()
{
int i;
for (i=0; i<30; i++)
{
printf("The %d th charactor is: %c\n", i, (char)('a' + i%26));
}
eturn 0;
}
int Test2(int num)
{
int i;
for (i=0; i<30; i++)
{
printf("The %d th charactor is: %c\n", i, (char)('a' + i%26));
}
return 0;
}
void Caller1(void (*ptr)())//指向函数的指针作函数参数
{
(*ptr)();
}
void Caller2(int n, int (*ptr)())//指向函数的指针作函数参数,这里第一个参数是为指向函数的指针服务的,
{ //不能写成void Caller2(int (*ptr)(int n)),这样的定义语法错误。
(*ptr)(n);
return;
}
int main()
{
printf("************************\n");
Caller1(Test1); //相当于调用Test2();
printf("&&&&&&************************\n");
Caller2(30, Test2); //相当于调用Test2(30);
return 0;
}
以上通过将回调函数的地址传给调用者从而实现调用,但是需要注意的是带参回调函数的用法。要实现回调,必须首先定义函数指针。函数指针的定义这里稍微提一下。比如:
int (*ptr)();这里ptr是一个函数指针,其中(*ptr)的括号不能省略,因为
括号的优先级高于星号,那样就成了一个返回类型为指向整型类型指针的函数声明了
对指针的应用是C语言编程的精髓所在,而回调函数就是C语言里面对函数指针的高级应用。简而言之,回调函数是一个通过函数指针调用的函数。如果你把函数指针(函数的入口地址)传递给另一个函数,当这个函数指针被用来调用它所指向的函数时,我们就说这个函数是回调函数。
Java的回调函数使用: public abstract class SRTConditionBase { public static final int TYPE_CALLING = 1; public static final int TYPE_MEDIA = 2; public static final int TYPE_AIRMODE = 3; public static final int TYPE_WAKEUP = 4; public static final int TYPE_GPS = 5; public static final int TYPE_MODEM = 6; public static final int TYPE_FM = 7; public static final int TYPE_BT = 8; public static final int TYPE_WIFI = 9; public static final int TYPE_CPU = 10; public static final int TYPE_NET = 11; public static final int TYPE_DEVICE_ON_OFF = 12; public static final int STATUS_OPENING = 1000; public static final int STATUS_OPEN = 1001; public static final int STATUS_CLOSING = 1002; public static final int STATUS_CLOSE = 1003; public abstract void open(); public abstract void close(); public interface SRTCallback { public void OnSRTCallback(int type, int status, String param); } } public class ACondition extends SRTConditionBase { private SRTCallback mCallback; public ACondition(Context context, SRTCallback callback) { super(); this.mCallback = callback; } @Override public void open() { this.mCallback.OnSRTCallback(SRTConditionBase.TYPE_NET, SRTConditionBase.STATUS_OPEN, "open"); Log.d("leichi", "I'm Acondition...open"); } @Override public void close() { this.mCallback.OnSRTCallback(SRTConditionBase.TYPE_NET, SRTConditionBase.STATUS_CLOSE, "close"); Log.d("leichi", "I'm Acondition...close"); } } public class MainActivity extends Activity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); doTest(); } @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.main, menu); return true; } private void doTest() { ACondition aCondition = new ACondition(this, new myCallBack()); aCondition.open(); aCondition.close(); BCondition bCondition = new BCondition(this, new myCallBack()); bCondition.open(); bCondition.close(); } class myCallBack implements SRTConditionBase.SRTCallback { @Override public void OnSRTCallback(int type, int status, String param) { Log.d("leichi", "type = " + type + " status=" + status + " param=" + param); } } }