Android多线程的几种实现方式

提示:本文不涉及多线程框架,只采用安卓原生提供的多线程技术去实现多线程处理

1、通过继承Thread类或者实现Runnable接口去实现

 class TheadTask extends Thread{
        @Override
        public void run() {
            Log.d("MainActivity","TheadTask is running");
        }
    }

    class ThreadRunnable implements Runnable{

        @Override
        public void run() {
            Log.d("MainActivity","ThreadRunnable is running");
        }
      //用继承自Thread方式来实现多线程
        Thread task01=new TheadTask();
        task01.start();

        Thread task02=new TheadTask();
        task02.start();
        //用实现Runnable方式来实现多线程
        Thread task03=new Thread(new TheadTask());
        task03.start();

两种方式的区别:runnable是通过接口方式去实现的,因此可以用多个类去实现这个接口,通过接口,实现线程之间的数据共享。一般继承自Thread的无法共享数据。

2、通过线程池去实现

        //复用线程池的方式实现
        ExecutorService executorService = Executors.newCachedThreadPool();
        executorService.execute(new ExecutorServiceThread());

        //该线程池只有一个线程
        ExecutorService singleExecutorService = Executors.newSingleThreadExecutor();
        singleExecutorService.execute(new ExecutorServiceThread());
   class ExecutorServiceThread implements Runnable{

        @Override
        public void run() {
            Log.d("MainActivity","ExecutorServiceThread is running");
        }
    }

线程池里面可以使用已经创建好的线程,可以减少线程销毁创建时给程序带来的开销,当遇见调用频繁的任务时可以采用线程池的方式去实现

3、通过继承AsyncTask实现

   //目前谷歌弃用了,但是一些多线性框架还在使用
    /**
     * 第一个参数 doInBackground参数
     * 第二个参数onProgressUpdate的参数,如果不需要可以设为void
     * 第三个参数doInBackground返回值,onPostExecute的参数
     */
    class DownloadTask extends AsyncTask<String, Integer, String> {
        @Override
        protected void onPreExecute() {
            //在异步任务开始的时候准备资源
            super.onPreExecute();
        }

        //必须要实现
        @Override
        protected String doInBackground(String... strings) {
            //执行复杂耗时的任务,一定要慎用
            for (int i=0;i<100;i++){
                publishProgress(i);//如果不需要发布进度,可以不处理
            }
            return "AsyncTask任务";
        }



        @Override
        protected void onProgressUpdate(Integer... values) {
            //更新进度,如果不需要的可以不实现,将第二个参数置空即可
            super.onProgressUpdate(values);
        }

        @Override
        protected void onPostExecute(String s) {
            //在这里处理数据更新后的结果
            super.onPostExecute(s);
        }
    }

        //AsyncTask去执行
        DownloadTask downloadTask=new DownloadTask();
        //默认是串行,所以需要修改成并行
        downloadTask.executeOnExecutor(
                AsyncTask.THREAD_POOL_EXECUTOR,
                "www.baidu.com"
        );

很遗憾的是,AsyncTask在现在已经是被谷歌弃用了,在使用AsyncTask的时候也要时刻注意防止内存泄露,同时AsyncTaks默认是串行方式去执行任务的,因此当有多个任务的时候,需要设置为并行方式 executeOnExecutor,AsyncTask.THREAD_POOL_EXECUTOR,去提高效率。虽然现在已经被弃用,但是一些多线程框架还是在使用,因此多了解一下没有坏处。

4、通过handle实现


        //handle去执行
        Handler handler=new Handler(Looper.myLooper());
        handler.post(new Runnable() {
            @Override
            public void run() {
                Log.d("MainActivity","handler is running");
            }
        });

handle一般用于主线程中,主线程调用handle,子线程负责处理请求数据,然后更新ui

5、通过IntentService实现

   class TaskIntentService extends IntentService{

        /**
         * @param name
         * @deprecated
         */
        public TaskIntentService(String name) {
            super(name);
        }

        @Override
        protected void onHandleIntent(@Nullable Intent intent) {
           //处理任务
            for (int i= 0;i<100;i++) {
                try {
                    Thread.sleep(100);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                sendProgress(i, 100);
            }
            Log.d("MainActivity","onHandleIntent");

        }
        private void sendProgress(int currentProgress,int totalProgress) {
            //得到处理后的通知可以用广播去通知
            Intent intent = new Intent();
            intent.setAction("xxxxxxx");
            intent.putExtra("current", currentProgress);
            intent.putExtra("total", totalProgress);
            sendBroadcast(intent);
        }

    }

IntentService这个在当前中也被谷歌弃用了,这是一个服务,在执行任务结束后服务生命周期就会结束(可查看源码,当onHandleIntent结束时就会调用终止函数),因此不适合去处理一些需要持续记录数据的操作

总结

看了前面这么多种安卓内置的多线程操作后,感兴趣的也可以去研究一下框架Rxjava,在线程中处理还算是可以的。创作不易,请勿下次一定。

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Android实现多线程几种方式有以下几种方法。首先,可以使用Java的Thread类来创建和管理线程。这种方式需要手动创建线程对象,并在run()方法中编写线程的逻辑。其次,可以使用Java的Runnable接口来实现多线程。这种方式需要创建一个实现了Runnable接口的类,并将其作为参数传递给Thread类的构造函数。然后,可以使用Handler类来实现多线程。通过Handler的post()或postDelayed()方法,可以将任务添加到主线程的消息队列中,从而在主线程中执行异步操作。此外,还可以使用AsyncTask类来实现多线程。AsyncTask是Android提供的一个封装好的线程池,可以方便地在后台执行耗时操作,并在主线程中更新UI。通过重写AsyncTask的doInBackground()方法来执行耗时操作,并通过onPostExecute()方法来更新UI。需要注意的是,AsyncTask必须在主线程中创建实例,并且execute()方法也必须在主线程中调用。另外,Android 3.0之后,可以使用executeOnExecutor()方法来实现并发执行多个AsyncTask任务。总结起来,Android实现多线程几种方式包括使用Thread类、Runnable接口、Handler类和AsyncTask类。\[1\]\[2\]\[3\] #### 引用[.reference_title] - *1* [Android——多线程的多种实现方式](https://blog.csdn.net/abliudede/article/details/104891324)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [Android开发中四种常用的多线程实现方式](https://blog.csdn.net/star_nwe/article/details/130140238)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值