• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >Android > 转载 Android 多线程处理之多线程用法大集合,android大集合

转载 Android 多线程处理之多线程用法大集合,android大集合

作者:网友 字体:[增加 减小] 来源:互联网 时间:2017-05-26

网友通过本文主要向大家介绍了android多线程,android 多线程下载,android多线程机制,android多线程编程,android多线程实例等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

转载 Android 多线程处理之多线程用法大集合,android大集合


handler.post(r)其实这样并不会新起线程,只是执行的runnable里的run()方法,却没有执行start()方法,所以runnable走的还是UI线程。

1.如果像这样,是可以操作ui,但是run还是走在主线程,见打印出来的Log线程名字是main,说明是主线程。

这就是为什么可以直接在run方法里操作ui,因为它本质还是ui线程

handler.post(new Runnable(){

  public void run(){

  Log.e("当前线程:",Thread.currrentThread.getName());//这里打印de结果会是main

  setTitle("哈哈");

      }

});

 

 

2.通过HandlerThread获取到looper却是可以新起线程,但是在这里的run方法里操作ui是不可能的,但是这显然有个缺点,如果你执行多次post(r)方法其实走的还是HandlerThread线程。假如你执行5次,n次,其实还是一次并且它们是串行的。假如下载5张图片,你会看到图片是下完第一张,才会去下第二张。

实践证明,只有是拥有主线程looper的handler才可以操作ui,而在主线程操作ui可以在handler的handlerMessage()方法中操作Ui,也可以在handler的post(r)的run方法里操作Ui.

在发送心跳包或者无限次连续请求一个接口时,为了避免建造太多的线程,可以使用这个HandlerThread,保证用一个线程就可以完成连续请求了。

HandlerThread ht = new HandlerThread("handler thread");

ht.start();

handler = new Handler(ht.getLooper());

handler.post(new Runnable(){//这里run()方法其实还是在等ht.start()调用

  public void run(){

  Log.e("当前线程:",Thread.currrentThread.getName());//这里打印的会是handler thread

  setTitle("哈哈");//这样必定报错

  //android.view.ViewRoot$CalledFromWrongThreadException: Only the original thread that created a view hierarchy can touch its views.

      }

});

private Runnable mGetTimeRunnable = new Runnable() {


  @Override
  public void run() {
    json = HttpUtils.getHttpText(Configs.getServerAddress(mContext));
    log("currentThread"+Thread.currentThread().getName());

  }
};

 

 

这样该怎么办呢,呵呵,可以无参构建一个handler。用这个handler来发送消息和处理消息,用上面的handler来开启新线程。

mainHandler = new Handler(){

  protecket void handlerMessage(Message msg){

    setTitle("哈哈");//这样就不会报错啦

  }

}

handler.post(new Runnable(){//这里run()方法其实还是在等ht.start()调用

  public void run(){

  Log.e("当前线程:",Thread.currrentThread.getName());//这里打印的会是handler thread

  mainHandler.sendEmpetMessage();//用mainHandler来发送消息

  //setTitle("哈哈");//这样必定报错

  //android.view.ViewRoot$CalledFromWrongThreadException: Only the original thread that created a view hierarchy can touch its views.

      }

});

 

打印Log:

3.其实第2个方法显得麻烦而且低效,用了2个handler,一个用来发起线程,一个用于处理消息。发起线程的handler必须拥有looper,所以还要实例化一个HanderThread;而处理消息的handler则不需要looper,因为它默认拥有主线程的looper,所以可以在这个handler处理ui。

其实可以只需要实例化一个handler,在主线程里构建一个无参的handler,然后由它发送和处理消息。而创建线程的任务就不用handler了,直接用new Thread(r).start();然后在r的run()方法里面处理逻辑事务。

用这样的模式下载5张图片,你就可能不会看到图片一张挨着一张展示出来,可能第2张先出来,也可能同时出来3张,5条线程很随机的。

private void loadImagesByThread(final String url,final int id){//通过Thread来new 出多个线程  
          
        new Thread(new Runnable(){  
  
            @Override  
            public void run() {  
                // TODO Auto-generated method stub  
                Log.e("当前线程:", ""+Thread.currentThread().getName());  
                Drawable drawable = null;  
                try {  
                    drawable = Drawable.createFromStream(new URL(url).openStream(), "image.gif");  
                } catch (MalformedURLException e) {  
                    // TODO Auto-generated catch block  
                    e.printStackTrace();  
                } catch (IOException e) {  
                    // TODO Auto-generated catch block  
                    e.printStackTrace();  
                }  
                Message msg = mainHandler.obtainMessage();  
                msg.what = 2012;  
                msg.arg1 = id;  
                msg.obj = drawable;  
                msg.sendToTarget();  
                  
            }  
              
        }).start();  
    }  

 

打印Log:

4.AsyncTask

用异步任务架构多任务模型其实也不是很健壮,得创建多个AsyncTask实例。一个AsyncTask仅执行一次,不能重复执行,快餐类的线程,一次用完。

实现AsyncTask子类,最重要的两个方法,一个是doInBackground(params);一个是onPostExecute(result)。在doInBackground()方法里处理耗时事务,并把结果返回,返回的值将在onPostExecute方法作为参数,然后就可以在onPostExecute()把结果展示在ui上面了。

步骤:

①实例化AsyncTask:

实例化AsyncTask然后通过task.exec(pamas);传进去参数,这个参数列表是动态的,可以是一个也可以使多个,长度可变。

  AsyncTask<params,values,reslut>,第一个参数会传进去这个方法doInBackground(params),第二个参数是数据更新的值,第三个是处理事务返回的结果。

②onPreExecute方法:

这个方法没有参数,也没有返回值,可以在这个方法里,做一些提醒。比如show一个Dialog,或者弹个Toast告诉用户开始下载啦。

 

③doInBackground(params)方法:

进入AsyncTask内部结构,首先将执行reslut doInBackground(params)方法,这个方法将处理耗时事务,exec()的参数将会传进这个方法做参数,而返回值将会作为onPostExecute()的参数。如果要更新进度的话,需执行publicProgress()方法。

 

④onProgressUpdate(values)方法:

这个方法的参数必须在doInBackground()方法里执行publicProgress()方法,这个方法将会把参数传递进onProgressUpdate()方法里,然后可以在这个方法做一些ui上的更新展示,比如进度条的值就可以通过这个values值动态改变。

⑤onPostExecute(result)方法:

这里就是事务处理完毕的走的方法,doInBackground方法执行的结果将传到这里,如果这个方法返回了数据。在这个方法里可以处理Ui,可以把处理完的数据展示在ui上。比如图片啊,文字啊,一切你想要的结果。 

private void loadImageByAsyncTask(final String url,final int id){//构建异步任务,这样就不用handler来处理消息了  
        DownloadTask task = new DownloadTask();  
        task.execute(""+id,url);//AsyncTask不可重复执行  
    }  
      
    class DownloadTask extends AsyncTask<String,Integer,Drawable>{  
  
        int id;  
        @Override  
        protected Drawable doInBackground(String... params) {//params保存url和控件id两个数据  
            // TODO Auto-generated method stub  
            Log.e("当前线程:", ""+Thread.currentThread().getName());  
            Drawable drawable = null;  
            this.id = Integer.parseInt(params[0]);  
            try {  
                drawable = Drawable.createFromStream(new URL(params[1]).openStream(), "image.gif");  
 



 
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 转载 Android 多线程处理之多线程用法大集合,android大集合
  • android --多线程下载过程分析
  • Android--线程详解
  • android关于线程的那些事,android那些事
  • Android线程优先级设置方法技巧,android线程优先级
  • Android特效专辑(八)——实现心型起泡飞舞的特效,让你的APP瞬间暖心
  • Android线程管理(三)&mdash;&mdash;Thread类的内部原理、休眠及唤醒,androidthread

相关文章

  • 2017-05-26致DBA:为什么你经常犯错,是因为你做的功课不够
  • 2017-05-26DB2_Tips_Tricks_04 远程数据库之间复制数据
  • 2017-05-26linux设备驱动程序之时钟管理(4)----原来是孩儿他爹娘
  • 2017-05-26Android特效专辑(十二)——如何仿支付宝咻一咻功能实现波纹扩散特效
  • 2017-05-26Android 数据库SQLite 写入SD卡,androidsqlite
  • 2017-05-26Handler,Looper,HandlerThread浅析,handlerthreadlooper
  • 2017-05-26Android Studio下NDK的使用
  • 2017-05-26redis lru实现策略
  • 2017-05-26Amazon Alexa登录授权(Android),amazonandroid
  • 2017-05-26Android Studio Ndk 编程

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • android中使用图文并茂的按钮,android图文并茂
    • Linux(CentOS 7)命令行模式安装VMware Tools
    • Android之网络编程利用PHP操作MySql插入数据(四),androidmysql
    • ImageLoader,androidimageloader
    • Android 利用xUtils框架实现对sqllite的增删改查,xutilssqllite
    • 解决Android后台清理APP后,程序自动重启的问题,androidapp
    • EditText的setSelection属性,setselection
    • Android常用命令行-ADB,android-adb
    • Android中使用Handler以及CountDownTimer实现包含倒计时的闪屏页面,countdownview倒计时
    • android 所有焦点问题--Focus,android--focus

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有