C C++回调函数和java的回调函数

 回调函数是一个程序员不能显式调用的函数;通过将回调函数的地址传给调用者从而实现调用。回调函数使用是必要的,在我们想通过一个统一接口实现不同的内容,这时用回掉函数非常合适。比如,我们为几个不同的设备分别写了不同的显示函数: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);

        }

    }
}


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值