Android异步处理

在Android 中,不能在主UI线程里处理耗时操作,否则会造成阻塞,时间过长时(超过5秒),甚至造成系统提示是否要kill该进程。

(1)使用线程
注意不能在非主UI线程中更新界面,有时需结合Handler使用.

prgDialog = ProgressDialog.show(GbcJoy.this,"wait","data loading...", true);
Thread th = new Thread(new Runnable()
{
 public void run()
 {
  //prgDialog = ProgressDialog.show();//对话框的显示不能放在此处
  loadData();//time consuming operation
  //updateListView();//也不能在些更新主UI线程界面
  prgDialog.dismiss();
 }
});
th.start(); 


 

如果需要在耗时操作后,更新或通知主线程,可以通过如下方法:
(2) 使用Handler
 

 prgDialog = ProgressDialog.show(GbcJoy.this,"wait","data loading...", true);
  new Thread()
  {
   public void run()
   {
    loadData();//time consumng operation
    handler.sendEmptyMessage(0);//也可以使用下面的postUpdateList();
   }
  }.start();

 //其实下面两个方法都是在主UI线程里完成的(所以最好不要有耗时操作)
 //即使把该函数放在一个子线程里面去调,也是一样
 public void postUpdateList()
     {
      adpHandler.post(new Runnable() 
      {
       public void run() 
       {
        updateListView();
    prgDialog.dismiss();
       }
      });
     }
 private Handler handler =new Handler()
 {
  @Override
  //当有消息发送出来的时候就执行Handler的这个方法,这里不能做耗时操作,否则还是会阻塞主UI线程
  public void handleMessage(Message msg)
  {
   super.handleMessage(msg);
   updateListView();
   prgDialog.dismiss();
  }
 };


 

Android 开发中,处理耗时操作如网络请求、数据库访问、IO 操作等时,为避免阻塞主线程,提高应用程序的响应速度和用户体验,常使用异步线程框架。以下是几种常见的 Android 异步处理框架: - **AsyncTask**:一种简单的异步处理框架。在 Android 3.0 之前,若要同时执行超过 139 个异步任务,AsyncTask 会报错,需自行构造多线程异步任务处理框架;3.0 之后默认顺序执行异步任务,不会报错,也可自定义线程池执行器。不过,该框架已被废弃,存在较多问题,不建议在新代码中使用 [^1][^2][^3]。 示例代码如下: ```java import android.os.AsyncTask; import android.os.Bundle; import androidx.appcompat.app.AppCompatActivity; public class MainActivity extends AppCompatActivity { private MyAsyncTask mAsyncTask; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); // 创建并执行异步任务 mAsyncTask = new MyAsyncTask(); mAsyncTask.execute(); } @Override protected void onDestroy() { super.onDestroy(); // 在Activity销毁时取消异步任务 if (mAsyncTask != null) { mAsyncTask.cancel(true); } } private static class MyAsyncTask extends AsyncTask<Void, Void, Void> { @Override protected Void doInBackground(Void... voids) { // 执行耗时操作 return null; } } } ``` - **Kotlin 协程**:提供了简洁的代码和结构化并发,不易出错,适合用于处理异步操作。不过,使用该框架需要学习新概念,它是较为推荐的异步处理方式 [^1][^3]。 示例代码如下: ```kotlin import kotlinx.coroutines.* fun main() = runBlocking { val job = launch { // 模拟耗时操作 delay(1000) println("Task completed") } job.join() } ``` - **Executor**:可实现强大的线程管理和资源复用,但相对底层,管理复杂,需要手动处理线程切换,常用于管理大量后台任务 [^1][^3]。 示例代码如下: ```java import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; public class ExecutorExample { public static void main(String[] args) { ExecutorService executor = Executors.newFixedThreadPool(5); for (int i = 0; i < 10; i++) { final int taskId = i; executor.execute(() -> { System.out.println("Task " + taskId + " is running on thread " + Thread.currentThread().getName()); }); } executor.shutdown(); } } ``` - **RxJava**:是一个在 Java 虚拟机上使用可观测的序列来组成异步的、基于事件的程序的库,提供了丰富的操作符来处理异步数据流 [^1]。 示例代码如下: ```java import io.reactivex.rxjava3.core.Observable; import io.reactivex.rxjava3.schedulers.Schedulers; public class RxJavaExample { public static void main(String[] args) { Observable.just("Hello", "World") .subscribeOn(Schedulers.io()) .observeOn(Schedulers.single()) .subscribe(System.out::println); } } ``` - **Handler**:作为 Android 底层机制,使用灵活,但代码繁琐,容易出错,可用于了解原理和特定场景 [^3]。 示例代码如下: ```java import android.os.Handler; import android.os.Looper; import android.os.Message; public class HandlerExample { private static final int MSG_WHAT = 1; private Handler handler = new Handler(Looper.getMainLooper()) { @Override public void handleMessage(Message msg) { if (msg.what == MSG_WHAT) { System.out.println("Received message"); } } }; public void sendMessage() { Message message = Message.obtain(); message.what = MSG_WHAT; handler.sendMessage(message); } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值