android 多线程 异步消息处理 服务 学习笔记 (六)
三种多线程编程方法
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 多线程 异步消息处理 服务 学习笔记 (六)的更多相关文章
- Android多线程----异步消息处理机制之Handler详解
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/ ...
- # go微服务框架kratos学习笔记六(kratos 服务发现 discovery)
目录 go微服务框架kratos学习笔记六(kratos 服务发现 discovery) http api register 服务注册 fetch 获取实例 fetchs 批量获取实例 polls 批 ...
- ArcGIS Runtime for Android 使用异步GP服务绘制等值线
关于基于Android上ArcGIS Server GP服务的调用,已经有前辈给出了很好的例子: http://blog.csdn.net/esrichinacd/article/details/92 ...
- (转)ArcGIS Runtime for Android 使用异步GP服务绘制等值线
关于基于Android上ArcGIS Server GP服务的调用,已经有前辈给出了很好的例子: http://blog.csdn.net/esrichinacd/article/details/92 ...
- Spring Cloud微服务学习笔记
Spring Cloud微服务学习笔记 SOA->Dubbo 微服务架构->Spring Cloud提供了一个一站式的微服务解决方案 第一部分 微服务架构 1 互联网应用架构发展 那些迫使 ...
- Java IO学习笔记六:NIO到多路复用
作者:Grey 原文地址:Java IO学习笔记六:NIO到多路复用 虽然NIO性能上比BIO要好,参考:Java IO学习笔记五:BIO到NIO 但是NIO也有问题,NIO服务端的示例代码中往往会包 ...
- java之jvm学习笔记六-十二(实践写自己的安全管理器)(jar包的代码认证和签名) (实践对jar包的代码签名) (策略文件)(策略和保护域) (访问控制器) (访问控制器的栈校验机制) (jvm基本结构)
java之jvm学习笔记六(实践写自己的安全管理器) 安全管理器SecurityManager里设计的内容实在是非常的庞大,它的核心方法就是checkPerssiom这个方法里又调用 AccessCo ...
- Learning ROS for Robotics Programming Second Edition学习笔记(六) indigo xtion pro live
中文译著已经出版,详情请参考:http://blog.csdn.net/ZhangRelay/article/category/6506865 Learning ROS for Robotics Pr ...
- Typescript 学习笔记六:接口
中文网:https://www.tslang.cn/ 官网:http://www.typescriptlang.org/ 目录: Typescript 学习笔记一:介绍.安装.编译 Typescrip ...
随机推荐
- 深入理解JavaScript系列(26):设计模式之构造函数模式
介绍 构造函数大家都很熟悉了,不过如果你是新手,还是有必要来了解一下什么叫构造函数的.构造函数用于创建特定类型的对象——不仅声明了使用的对象,构造函数还可以接受参数以便第一次创建对象的时候设置对象的成 ...
- 深入理解JavaScript系列(15):函数(Functions)
介绍 本章节我们要着重介绍的是一个非常常见的ECMAScript对象——函数(function),我们将详细讲解一下各种类型的函数是如何影响上下文的变量对象以及每个函数的作用域链都包含什么,以及回答诸 ...
- Windows映射网络驱动器提示错误
问题描述:Windows映射网络驱动器的时候,提示文件和打印机共享资源处于联机状态未对连接尝试检测到做出响应 解决方法:不同情况可能不一样,我的原因是,映射的Linux,防火墙处于开启状态,关闭了就可 ...
- linux下快速安装python3.xx
安装python3之前的准备工作: 当前环境是centos操作系统[已经安装了gcc++],在安装前需要安装zlib-devel包: yum install zlib-devel yum instal ...
- Observer(观察者)设计模式[转]
Observer设计模式中主要包括如下两类对象: Subject:监视对象,它往往包含着其他对象所感兴趣的内容.在本范例中,热水器就是一个监视对象,它包含的其他对象所感兴趣的内容,就是tempratu ...
- Thrift笔记(三)--Thrift框架通信源码分析
Thrift 客户端调用RPC的Demo public static void main(String[] args) throws Exception { TTransport transport ...
- 移除script标签引起的兼容性问题
一.应用场景: 有时候我们需要动态创建script标签实现脚本的按需加载,我们会为script标签绑定onload或者onreadystatechange事件,用于检测动态脚本是否加载并执行完毕,在事 ...
- Bash 终端快捷键
在终端下输大量的命令,有些快捷键还是挺有帮助的. 跳跃 跳到最后 ctrl + e (end) 跳到最前 ctrl + a (abcde....) 向后跳一个单词 alt + 右方向键 向前跳一个单词 ...
- SQL语句执行与结果集的获取
title: SQL语句执行与结果集的获取 tags: [OLEDB, 数据库编程, VC++, 数据库] date: 2018-01-28 09:22:10 categories: windows ...
- linux环境下 mysql数据库忘记密码 处理办法
整个修改过程大概3-10分钟(看个人操作),这个时间内mysql出于不需要密码就能登陆的状态,请设法保证系统安全 不罗嗦直接上步骤 1.vi /etc/my.cnf 在[mysqld]下,添加一句:s ...