三种多线程编程方法

1     class Mythread extends Thread{
@Override
public void run(){}
}
new Mythread().start()
2 class Mythread implements Runnable{
@Override
public void run(){}
}
Mythread myThread=new Mythread();
new Thread(myThread).start();
3 new Thread{new Runnable{
@Override
public void run(){}
}.start();

异步消息处理机制(使用message更新ui)

public class MainActivity extends Activity implements OnClickListener{
Button button;
TextView text;
public static final int change=1;
private Handler handler=new Handler(){
public void handleMessage(Message ms){
switch(ms.what){
case change:
text.setText("nice to meet you");
break;
default:
break;
}
}
};
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
button=(Button) findViewById(R.id.change_Button);
text=(TextView)findViewById(R.id.text);
button.setOnClickListener(this); }
public void onClick(View v){
switch (v.getId()) {
case R.id.change_Button:
new Thread(new Runnable(){
public void run(){
Message ms=new Message();
ms.what=change;
handler.sendMessage(ms);
}
}).start();
break;
default:
break;
} }
}

使用AsynvTask更新ui

class DownloadTask extends AsyncTask<Void,Integer,Boolean>{
@Override
protected void onPreExecute(){
progressDialog.show();
}
@0verride
protected Boolean doInBackground(Void...params){
try{
while(true){
int downloadPercent=doDownload();
publishProgress(downloadPercent);
if(downloadPercent>=100){
break;
}
}
}catch(Exception e){
return false;
}
return true;
}
protected void onProgressUpdate(Integer...values){
progressDialog.setMessage("Download"+values[0]+"%");
}
@Override
protected void onPostExecute(Boolean result){
progressDialog.dismiss();
if(result){
Toast.makeText(context,"Download succeeded",Toast.LENGTH_SHORT).show();
}else{
Toast.makeText(context,"Download failed",Toast.LENGTH_SHORT).show();
}
}
}

定义一个服务

服务定义完成后要使用的话必须同android其他三大组件一样在manifest中注册才行 <service  android:name=".MyService"></service>
 在活动中启动或停止服务的话使用intent
  Intent intent=new Intent(this,Myservice.class);
  startService(intent);
  Intent intent1=new Intent(this,Myservice.class);
  stopService(intent1);或者是在服务的定义中调用stopSelf()来停止服务

public class MyService extends Service{
public IBinder onBind(Intent intent){
return null;
}
public void onCreate(){
super.onCreate();
}
public int onStartCommand(Intent inten,int flags,int startId){
return super.onStartCommand(intent,flags,startId);
}
public void onDestroy(){
super.onDestroy();
}
}

活动和服务进行通信:使用onBind()

public class MyService extends Service{
private DownloadBinder mBinder=new DownloadBinder();
class DownloadBinder extends Binder{
public void startDownload(){
Log.d("MyService","startdownload");
}
public int getProgress(){
Log.d("MyService","getProgress")
return 0
}
}
public IBinder onBind(Intent intent){
return mBinder;
}
}
主活动中调用 先建立一个ServieceConnection匿名类
private ServiceConnection connection=new ServiceConnection(){
public void onServiceDisconnected(ComponentName name){}
public void onServiceConnected(ComponentName name,IBinder service){
MyService.DownloadBinder downloadBinder=(MyService.DownloadBinder)service;获得一个DownloadBinder实例
downloadBinder.startDownload();
downloadBinder.getProgress();
}
}
Intent bindintent=new Intent(this,MyService.class);
bindService(bindintent,connection,BIND_ANTO_CREATE);绑定服务并且绑定后自动创建
。。
unbinderService(connection);解绑,connection为前面定义的ServiceConnection实例
注意服务在任何活动中都是通用的 可以和任何activity 进行绑定

使用intentService(可以自己开启线程并且可以自动停止)
定义:

public class MyIntentService  extends IntentService {

    public MyIntentService( ) {
super("MyIntentService");
// TODO Auto-generated constructor stub
}
protected void onHandleIntent(Intent intent){
Log.d("MyIntentService","thread id id"+Thread.currentThread().getId());
}
public void onDestroy(){
super.onDestroy();
Log.d("MyIntentService","ondestroy exe");
} }
在活动中启动或者的方法是一样的
Intent intentService=new Intent(this,MyIntentService.class);
startSercice(intentService);
同样要进行注册注册方法和普通服务一样的

服务的最佳实践  定时循环开启一项服务:

public class LongRunningService extends Service {
public IBinder onBind(Intent intent){
return null;
}
public int onStartCommand(Intent intent,int flags,int startId){
new Thread(new Runnable(){
public void run(){
Log.d(".","");
}
}).start();
AlarmManager manager=(AlarmManager)getSystemService(ALARM_SERVICE);
int anHour=60*60*1000;
long triggerAtTime=SystemClock.elapsedRealtime()+anHour;
Intent i=new Intent(this,AlarmReceiver.class);
PendingIntent pi=PendingIntent.getBroadcast(this,0,i,0);
manager.set(AlarmManager.ELAPSED_REALTIME_WAKEUP,triggerAtTime,pi);
return super.onStartCommand(intent, flags, startId); }
} 定义一个广播接收器
public class AlarmReceiver extends BroadcastReceiver{
public void onReceive(Context context,Intent intent){
Intent i=new Intent(context,LongRunningService.class);
context.startService(i);
}
}
在活动中进行启动这个服务 一旦启动就会不断重复
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Intent intent=new Intent(this,LongRunningService.class);
startService(intent);
}
注意 :现在的手机当中为了省电,当存在多个Alarm定时任务的时候,他会
把时间相近的几个任务集合在一起去唤醒cpu,所以会有一些时间上的误差,为了准确无误,可以
把服务中manager.set()改为manager.setExact()

android 多线程 异步消息处理 服务 学习笔记 (六)的更多相关文章

  1. Android多线程----异步消息处理机制之Handler详解

    ​[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/ ...

  2. # go微服务框架kratos学习笔记六(kratos 服务发现 discovery)

    目录 go微服务框架kratos学习笔记六(kratos 服务发现 discovery) http api register 服务注册 fetch 获取实例 fetchs 批量获取实例 polls 批 ...

  3. ArcGIS Runtime for Android 使用异步GP服务绘制等值线

    关于基于Android上ArcGIS Server GP服务的调用,已经有前辈给出了很好的例子: http://blog.csdn.net/esrichinacd/article/details/92 ...

  4. (转)ArcGIS Runtime for Android 使用异步GP服务绘制等值线

    关于基于Android上ArcGIS Server GP服务的调用,已经有前辈给出了很好的例子: http://blog.csdn.net/esrichinacd/article/details/92 ...

  5. Spring Cloud微服务学习笔记

    Spring Cloud微服务学习笔记 SOA->Dubbo 微服务架构->Spring Cloud提供了一个一站式的微服务解决方案 第一部分 微服务架构 1 互联网应用架构发展 那些迫使 ...

  6. Java IO学习笔记六:NIO到多路复用

    作者:Grey 原文地址:Java IO学习笔记六:NIO到多路复用 虽然NIO性能上比BIO要好,参考:Java IO学习笔记五:BIO到NIO 但是NIO也有问题,NIO服务端的示例代码中往往会包 ...

  7. java之jvm学习笔记六-十二(实践写自己的安全管理器)(jar包的代码认证和签名) (实践对jar包的代码签名) (策略文件)(策略和保护域) (访问控制器) (访问控制器的栈校验机制) (jvm基本结构)

    java之jvm学习笔记六(实践写自己的安全管理器) 安全管理器SecurityManager里设计的内容实在是非常的庞大,它的核心方法就是checkPerssiom这个方法里又调用 AccessCo ...

  8. Learning ROS for Robotics Programming Second Edition学习笔记(六) indigo xtion pro live

    中文译著已经出版,详情请参考:http://blog.csdn.net/ZhangRelay/article/category/6506865 Learning ROS for Robotics Pr ...

  9. Typescript 学习笔记六:接口

    中文网:https://www.tslang.cn/ 官网:http://www.typescriptlang.org/ 目录: Typescript 学习笔记一:介绍.安装.编译 Typescrip ...

随机推荐

  1. 树莓派3(Raspbain系统)安装.net环境

    因为公司之前做的网站项目都是基于微软的.net平台,现在需要在树莓派3上测试它是否能负载起正常的访问请求.最开始直接的想到微软3月份刚发布针对于树莓派3的win10系统,其实说是win10,也就是一个 ...

  2. 腾讯云CDB的AI技术实践:CDBTune

    欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 作者:邢家树,高级工程师,目前就职于腾讯TEG基础架构部数据库团队.腾讯数据库技术团队维护MySQL内核分支TXSQL,100%兼容原生My ...

  3. 【Spring Cloud】与Spring Boot版本匹配关系

    Spring Cloud版本演进情况如下: 版本名称 版本Finchley snapshot版Edgware snapshot版Dalston SR1 当前最新稳定版本Camden SR7 稳定版本B ...

  4. js实现图片延时加载的原理

    实现原理: 附:(http://www.cnblogs.com/fishtreeyu/archive/2011/03/12/1982067.html) 把所有需要延时加载的图片改成如下的格式: < ...

  5. 3D开源推荐:3DWebExplorer

    开源网址:https://github.com/irconde/3DWebExplorer 介绍:演示如何内嵌Google Earth 插件,开发面向公众的3D旅游展示平台

  6. JSP禁用缓存的方式 response.setHeader( "Pragma", "no-cache" ); setDateHeader("Expires", 0);

    JSP禁用缓存的方式    使用服务器端控制AJAX页面缓存:        response.setHeader( "Pragma", "no-cache" ...

  7. 从java9开始就不再提供32位jdk

  8. 关于移动App开发前端UI框架选择

    问题:现在移动开发各种必须,而移动开发纠结在于怎样快速高效的开发出来. 做web开发有些年头了,成熟的前端套件(easyui,extjs,jqueryui)很是方便,可以开发出来规范一直的产品,各种组 ...

  9. gridview导出exe处理时遇到RegisterForEventValidation can only be called during Render();错误

    如题,今天在利用GridView作execl导出时,遇到RegisterForEventValidation can only be called during Render();问题.根据网上找到的 ...

  10. C#转Java之路之二:多线程原子变量

    多线程操作会带来不一致性,为了实现一直性.我们可以用关键字:synchronized同步对象或者volatile轻量级.内存可见性. 两个关键字使用对比: 1.synchronized比较重,属于悲观 ...