Android到处都在使用的回调分析
回调函数:
回调函数就是一个通过函数指针调用的函数。如果你把函数的指针(地址)作为参数传递给另一个函数,当这个指针被用为调用它所指向的函数时,我们就说这是回调函数。回调函数不是由该函数的实现方直接调用,而是在特定的事件或条件发生时由另外的一方调用的,用于对该事件或条件进行响应。
Java 中没有指针的概念,通过接口和内部类的方式实现回调的功能:
1. 定义接口 Callback ,包含回调方法 callback()
2. 在一个类Caller 中声明一个Callback接口对象 mCallback
3. 在程序中赋予Caller对象的接口成员(mCallback) 一个内部类对象如
new Callback(){
callback(){
//函数的具体实现
}
这样,在需要的时候,可用Caller对象的mCallback接口成员调用callback()方法,完成回调.
Android事件侦听器是视图View类的接口,包含一个单独的回调方法。这些方法将在视图中注册的侦听器被用户界面操作触发时由Android框架调用。回调方法被包含在Android事件侦听器接口中:
例如,Android 的view 对象都含有一个命名为 OnClickListener 接口成员变量,用户的点击操作都会交给 OnClickListener的 OnClick() 方法进行处理。
开发者若需要对点击事件做处理,可以定义一个 OnClickListener 接口对象,赋给需要被点击的 view的接口成员变量OnClickListener,一般是用 view 的setOnClickListener() 函数来完成这一操作。
当有用户点击事件时,系统就会回调被点击view的OnClickListener接口成员的OnClick()方法。
实例(对于Android界面上Button点击事件监听的模拟):
1.定义接口
public interface OnClickListener {
public void OnClick(Button b);
}
2. 定义Button
public class Button {
OnClickListener listener;
public void click() {
listener.OnClick(this);
}
public void setOnClickListener(OnClickListener listener) {
this.listener = listener;
}
}
3. 将接口对象OnClickListener 赋给 Button的接口成员
public class Activity {
public Activity() {
}
public static void main(String[] args) {
Button button = new Button();
button.setOnClickListener(new OnClickListener(){
@Override
public void OnClick(Button b) {
System.out.println("clicked");
}
});
button.click(); //user click,System call button.click();
}
}
要定义这些方法并处理你的事件,在你的活动中实现这个嵌套接口或定义它为一个匿名类:
采用匿名类方式实现:
- // Create an anonymous implementation of OnClickListener
- private OnClickListener mCorkyListener = new OnClickListener() {
- public void onClick(View v) {
- // do something when the button is clicked
- }
- };
- protected void onCreate(Bundle savedValues) {
- ...
- // Capture our button from layout
- Button button = (Button)findViewById(R.id.corky);
- // Register the onClick listener with the implementation above
- button.setOnClickListener(mCorkyListener);
- ...
- }
采用嵌套接口实现:
- public class ExampleActivity extends Activity implements OnClickListener {
- protected void onCreate(Bundle savedValues) {
- ...
- Button button = (Button)findViewById(R.id.corky);
- button.setOnClickListener(this);
- }
- // Implement the OnClickListener callback
- public void onClick(View v) {
- // do something when the button is clicked
- }
- ...
- }
下面以MMS模块中的实际例子为例进行说明:
例子1:
//ConversationListAdapter.java private OnContentChangedListener mOnContentChangedListener; public interface OnContentChangedListener { void onContentChanged(ConversationListAdapter adapter); } public void setOnContentChangedListener(OnContentChangedListener l) { mOnContentChangedListener = l; } @Override protected void onContentChanged() { if (mCursor != null && !mCursor.isClosed()) { if (mOnContentChangedListener != null) { mOnContentChangedListener.onContentChanged(this); } } } //ConversationList.java private final ConversationListAdapter.OnContentChangedListener mContentChangedListener = new ConversationListAdapter.OnContentChangedListener() { public void onContentChanged(ConversationListAdapter adapter) { startAsyncQuery(); } }; private void initListAdapter() { mListAdapter = new ConversationListAdapter(this, null); mListAdapter.setOnContentChangedListener(mContentChangedListener); setListAdapter(mListAdapter); getListView().setRecyclerListener(mListAdapter); }
例子2:
//WorkingMessage.java private final MessageStatusListener mStatusListener; public interface MessageStatusListener { /** * Called when the protocol for sending the message changes from SMS * to MMS, and vice versa. * * @param mms If true, it changed to MMS. If false, to SMS. */ void onProtocolChanged(boolean mms); /** * Called when an attachment on the message has changed. */ void onAttachmentChanged(); /** * Called just before the process of sending a message. */ void onPreMessageSent(); /** * Called once the process of sending a message, triggered by * {@link send} has completed. This doesn't mean the send succeeded, * just that it has been dispatched to the network. */ void onMessageSent(); /** * Called if there are too many unsent messages in the queue and we're not allowing * any more Mms's to be sent. */ void onMaxPendingMessagesReached(); /** * Called if there's an attachment error while resizing the images just before sending. */ void onAttachmentError(int error); } private WorkingMessage(ComposeMessageActivity activity) { mActivity = activity; mContentResolver = mActivity.getContentResolver(); mStatusListener = activity; //设置 mAttachmentType = TEXT; mText = ""; } public static WorkingMessage createEmpty(ComposeMessageActivity activity) { // Make a new empty working message. WorkingMessage msg = new WorkingMessage(activity); return msg; } private void sendSmsWorker(String msgText, String semiSepRecipients, long threadId) { String[] dests = TextUtils.split(semiSepRecipients, ";"); if (LogTag.VERBOSE || Log.isLoggable(LogTag.TRANSACTION, Log.VERBOSE)) { LogTag.debug("sendSmsWorker sending message: recipients=" + semiSepRecipients + ", threadId=" + threadId); } MessageSender sender = new SmsMessageSender(mActivity, dests, msgText, threadId); try { sender.sendMessage(threadId); // Make sure this thread isn't over the limits in message count Recycler.getSmsRecycler().deleteOldMessagesByThreadId(mActivity, threadId); } catch (Exception e) { Log.e(TAG, "Failed to send SMS message, threadId=" + threadId, e); } mStatusListener.onMessageSent(); //调用 } //ComposeMessageActivity.java public class ComposeMessageActivity extends Activity implements View.OnClickListener, TextView.OnEditorActionListener, MessageStatusListener/*实现该接口*/, Contact.UpdateListener { .... public void onProtocolChanged(final boolean mms) {//实现onProtocolChanged接口 // Have to make sure we're on the UI thread. This function can be called off of the UI // thread when we're adding multi-attachments runOnUiThread(new Runnable() { public void run() { toastConvertInfo(mms); setSendButtonText(mms); } }); } .... public void initialize(Bundle savedInstanceState, long originalThreadId) { Intent intent = getIntent(); // Create a new empty working message. mWorkingMessage = WorkingMessage.createEmpty(this); // }
参考:
回调机制在 Android 监听用户界面操作中的体现 http://www.cnblogs.com/greatstar/archive/2011/03/02/1968999.html
百度百科: 回调函数 http://baike.baidu.com/view/414773.html?fromTaglist
java中回调函数的实例说明 http://www.blogjava.net/songfei/articles/126093.html
Android事件侦听浅谈 http://developer.51cto.com/art/201001/180846.htm
<script type="text/javascript"></script><script type="text/javascript"></script>
发表评论
-
资料上传备份
2012-07-02 07:28 0对付对付对付对付 -
Android-sharedUserId数据权限
2012-05-02 10:16 1445Android-sharedUserId数据权限 An ... -
Android Service学习之本地服务
2012-04-18 10:28 863转: Android Service学习之本地服务 htt ... -
match_parent和fill_parent的区别 .
2012-02-18 11:49 1840match_parent和fill_parent的区别 有 ... -
Android中SQLiteOpenHelper类的onUpgrade方法的作用
2012-02-09 11:50 4601Android中SQLiteOpenHelper类的onUpg ... -
Android启动各种系统服务线程
2012-02-09 10:59 1936Android启动各种系统服务 ... -
android
2012-02-08 09:22 0Android数据库内容变化的监听 首先介绍内容监 ... -
在线升级Android应用程序的思路
2012-02-07 11:34 880在线升级Android应用程序的思路 http://www. ... -
Android数据库内容变化的监听
2012-02-07 11:31 6033Android数据库内容变化的监听 首先介绍内容监 ... -
android中的数据库操作
2012-02-07 10:50 1451android中的数据库操作 ... -
SQLiteOpenHelper类与自动升级数据库
2012-02-07 10:31 2283SQLiteOpenHelper类与自动升级数据库 S ... -
SQLite外键的实现
2012-02-07 10:30 1717SQLite外键的实现 SQLite现在的版本还不支持 ... -
android中LayoutInflater的使用
2011-12-21 11:35 1932android中LayoutInflater的使用 ... -
SIM卡满处理流程分析
2011-12-19 15:15 1882SIM卡满处理流程分析 //框架层分析 // SMSD ... -
短信发送状态报告流程分析
2011-12-19 15:07 2392短信发送状态报告流程分析 //应用层分析: //Sms ... -
Android平台 短信接送流程剖析(含编码)
2011-12-16 15:29 3228Android平台 短信接送流程剖析(含编码) ... -
修改语言环境方法
2011-12-16 15:20 1039修改语言环境方法 private void se ... -
Android平台 短信发送流程剖析(含编码)
2011-12-12 17:12 4334Android平台 短信发送流程剖析(含编码) 本文对A ... -
Android 应用程序签名
2011-11-27 11:34 1641Android 应用程序签名 转:http://www ... -
理解Android 上的安全性
2011-11-27 11:18 1473理解 Android 上的安全性 ...
相关推荐
在这个"android开发回调使用.zip"文件中,我们可以预期包含的是关于如何在Android应用程序中有效地使用回调的教程或代码示例。 首先,我们要理解什么是回调。在编程中,回调是一种设计模式,它允许一个函数或方法在...
在Android平台上,开发一款应用程序来采集图像并进行实时处理是一项常见的任务,特别是在摄像头应用或图像分析项目中。本文将深入探讨如何实现这个功能,重点在于理解Android的相机API以及如何设置预览回调来处理...
通过分析和学习这个项目,你可以更直观地了解上述知识点的实现方式,包括如何创建Socket连接、实现心跳包、处理消息回调以及服务端的多线程处理等。 总结,实现“Android-Socket长连接通信心跳包消息回调Java服务端...
在Android开发中,远程回调(Remote Callback)是一种用于在应用程序组件之间进行异步通信的技术,尤其是在服务和服务之间的交互中特别常见。它允许一个组件启动一个服务,并在服务完成某些操作后接收通知,而无需...
在实际项目中,接口回调的应用非常广泛,例如在Android开发中,事件监听、网络请求、UI更新等场景都会用到这种机制。通过合理运用接口回调和匿名内部类,开发者可以编写出更加高效、可维护的代码。 总结一下,接口...
在Java编程中,回调和代理机制是两种非常重要的设计模式,它们在软件开发中起着关键的作用。这里,我们将通过一个具体的项目实例来探讨这两种机制。 首先,让我们深入理解回调机制。回调是一种允许一个对象在完成...
在Android开发中,自定义控件和回调函数的使用能够极大地增强应用的可定制性和交互性。下面将详细讲解如何实现这些功能。 1. **View的工作原理** Android中的View是UI元素的基础,它负责绘制界面和处理用户交互。...
在Android编程中,匿名内部类和回调函数是两个非常重要的概念,它们在事件处理、接口交互等场景中扮演着核心角色。这篇文章将深入探讨这两个概念,以及如何在实际开发中运用它们。 首先,让我们理解匿名内部类。...
在Android开发中,Handler回调机制是用于解决线程间通信的核心技术之一,它与Looper和Message紧密相连,共同构建了Android的消息处理系统。本篇将深入解析Handler回调机制,并通过提供的"handler的回调机制"DEMO来...
需要用astah工具打开,里面的数据建议以这样顺序 startRecorder->consumerData->dataProducer->request查看
libpcap是一个广泛使用的开源库,主要用于网络分析、故障诊断和安全监控,它在Windows、Linux和Unix等系统上都有应用。 首先,要使用libpcap在Android平台上进行网络包抓取,我们需要借助Android NDK(Native ...
在Android系统中,同步回调机制是一种常见的组件交互方式,它允许应用程序和服务之间进行通信和数据交换。然而,这种机制也可能成为安全漏洞的来源,因为恶意攻击者可以利用它来对系统服务和应用进行攻击。本文将...
JNI在很多场景下都非常有用,比如优化性能、使用现有的C/C++库、或者像在这个“JniCallback.zip”文件中所展示的,实现应用层与本地代码之间的回调功能。下面我们将深入探讨这个主题。 1. **JNI基础知识**: JNI是...
1. **注册URL Scheme**:在AndroidManifest.xml文件中,使用标签声明自定义的 scheme 和 host,如 `<data android:scheme="testa" />`。 2. **处理Intent**:在目标Activity中,通过覆写`onCreateIntent()`方法来...
源码可能包括设置相机参数、创建和启动流程、处理Mediapipe的回调以及更新UI等部分。为了调试和优化,你可以利用Mediapipe提供的日志和性能监控工具。 手势识别在Android应用中有很多实用场景,比如游戏控制、用户...
- **线程生命周期管理**:在本地线程中回调Java方法后,记得使用`JavaVM->DetachCurrentThread()`来分离线程,否则可能导致JVM泄漏。只有主线程(由Java方法启动的线程)是自动附着的,其他线程需要手动附着和分离。...
通过调用`startListening()`方法启动识别服务,监听用户的语音输入,然后通过`onResults()`回调获取识别结果。开发者可以据此实现根据语音指令执行对应的操作,例如控制音乐播放、搜索信息等。 2. **远程图片上传与...
- Handler引起的内存泄漏:当Handler与Looper关联,且Looper在主线程,即使Activity销毁,消息队列中的消息仍能回调到已销毁的Activity,导致内存泄漏。 分析"AndroidHelloWorld"的堆 Dump 文件,我们可以通过MAT...
在Android开发中,回调函数通常与组件的生命周期紧密相关,例如Activity、Service和BroadcastReceiver等组件都拥有自己的生命周期回调方法,如onCreate()、onStart()、onStop()等。这些回调方法会在组件生命周期的...