android static达到Service与Activity于Handler沟通
供static理解力,仅适用于static理解力,不喜勿喷
第一种方式:离Service中获取Activity的static变量,调用该静态变量的getHandler()获取Handler进行发送消息
MainActivity:
package com.example.test; import android.support.v7.app.ActionBarActivity;
import android.support.v7.app.ActionBar;
import android.support.v4.app.Fragment;
import android.support.v4.content.IntentCompat;
import android.content.Context;
import android.content.Intent;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.ViewGroup;
import android.os.Build; public class MainActivity extends ActionBarActivity { Handler handler;
//static Handler handler;
Context context; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); context = getApplicationContext(); handler = new Handler(){
@Override
public void handleMessage(Message msg) {
String string = (String)msg.obj;
Log.e("Log",string);
super.handleMessage(msg);
}
}; TestService.startSevice(MainActivity.this); Log.e("Log","TestService start ok" );
} @Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.main, menu);
return true;
} @Override
public boolean onOptionsItemSelected(MenuItem item) {
int id = item.getItemId();
if (id == R.id.action_settings) {
return true;
}
return super.onOptionsItemSelected(item);
} public Handler getHandler(){
return this.handler;
} public Context getContext(){
return this.context;
}
}
TestService:
package com.example.test; import android.app.Service;
import android.content.Context;
import android.content.Intent;
import android.os.Handler;
import android.os.IBinder;
import android.os.Message;
import android.support.v4.content.IntentCompat;
import android.util.Log; public class TestService extends Service { private static MainActivity mainActivity; static void startSevice(Context c) {
mainActivity = (MainActivity) c;
Intent in = new Intent(c, TestService.class);
c.startService(in);
} @Override
public IBinder onBind(Intent intent) {
// TODO Auto-generated method stub
return null;
} @Override
public void onCreate() {
Log.e("Log","TestService start ok2" );
super.onCreate();
} @Override
public int onStartCommand(Intent intent, int flags, int startId) {
//new TestThread(mainActivity).start();
new TestThread(mainActivity).start(); return super.onStartCommand(intent, flags, startId);
} class TestThread extends Thread {
private Context context;
private Handler handler;
public TestThread(){ } public TestThread(Context context) {
this.context = context;
this.handler = ((MainActivity) context).getHandler();
} @Override
public void run() {
Message msg = new Message();
msg.obj = "HelloWorld!";
handler.sendMessage(msg);
//MainActivity.handler.sendMessage(msg);
super.run();
}
}
}
另外一种方式:将Activity中的Handler设置为static,然后直接在Service中调用Activity的静态Handler的进行发送消息
MainActivity:
package com.example.test; import android.support.v7.app.ActionBarActivity;
import android.support.v7.app.ActionBar;
import android.support.v4.app.Fragment;
import android.support.v4.content.IntentCompat;
import android.content.Context;
import android.content.Intent;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.ViewGroup;
import android.os.Build; public class MainActivity extends ActionBarActivity { //Handler handler;
static Handler handler;
//Context context; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); //context = getApplicationContext(); handler = new Handler(){
@Override
public void handleMessage(Message msg) {
String string = (String)msg.obj;
Log.e("Log",string);
super.handleMessage(msg);
}
}; //TestService.startSevice(MainActivity.this);
Intent intent = new Intent(MainActivity.this,TestService.class);
startService(intent); Log.e("Log","TestService start ok" );
} @Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.main, menu);
return true;
} @Override
public boolean onOptionsItemSelected(MenuItem item) {
int id = item.getItemId();
if (id == R.id.action_settings) {
return true;
}
return super.onOptionsItemSelected(item);
} public Handler getHandler(){
return this.handler;
} //public Context getContext(){
// return this.context;
//} }
TestService:
package com.example.test; import android.app.Service;
import android.content.Context;
import android.content.Intent;
import android.os.Handler;
import android.os.IBinder;
import android.os.Message;
import android.support.v4.content.IntentCompat;
import android.util.Log; public class TestService extends Service { //private static MainActivity mainActivity; //static void startSevice(Context c) {
// mainActivity = (MainActivity) c;
// Intent in = new Intent(c, TestService.class);
// c.startService(in);
//} @Override
public IBinder onBind(Intent intent) {
// TODO Auto-generated method stub
return null;
} @Override
public void onCreate() {
Log.e("Log","TestService start ok2" );
super.onCreate();
} @Override
public int onStartCommand(Intent intent, int flags, int startId) {
//new TestThread(mainActivity).start();
new TestThread().start(); return super.onStartCommand(intent, flags, startId);
} class TestThread extends Thread {
private Context context;
private Handler handler;
public TestThread(){ } public TestThread(Context context) {
this.context = context;
this.handler = ((MainActivity) context).getHandler();
} @Override
public void run() {
Message msg = new Message();
msg.obj = "HelloWorld!";
//handler.sendMessage(msg);
MainActivity.handler.sendMessage(msg);
super.run();
}
}
}
Java Static:作为修饰符, 能够用来修饰变量、方法、代码块(但绝对不能修饰类)。
1、修饰变量:
类的全部对象共有的一个属性。也称为类变量。这类似于C语言中的全局变量。类变量在类载入的时候初始化,并且仅仅被初始化一次。在程序中不论什么对象对静态变量做改动,其它对象看到的是改动后的值。
因此类变量能够用作计数器。另外,Java
Static变量能够用类名直接訪问,而不必须要对象。
2、修饰方法:
类的全部对象共有的一个功能。称为静态方法。
静态方法也能够用类名直接訪问。而不必须要对象。所以在静态方法里不能直接訪问非静态变量和非静态方法,在Static方法里不能出现this或者super等keyword。
3、修饰Java代码块:
用static去修饰类里面的一个独立的代码块。称为静态代码块。静态代码块在类第一次被载入的时候运行,并且仅仅运行一次。
静态代码块没有名字,因此不能显式调用,而仅仅有在类载入的时候由虚拟机来调用。它主要用来完毕一些初始化操作。
4、说说类载入:
JVM在第一次使用一个类时,会到classpath所指定的路径里去找这个类所相应的字节码文件, 并读进JVM保存起来,这个过程称之为类载入。
可见,不管是变量,方法,还是代码块,仅仅要用static修饰,就是在类被载入时就已经"准备好了",也就是能够被使用或者已经被运行。都能够脱离对象而运行。
反之,假设没有static。则必须通过对象来訪问。
引用地址:http://blog.csdn.net/sniperwang/article/details/4744753
版权声明:本文博主原创文章,博客,未经同意不得转载。
android static达到Service与Activity于Handler沟通的更多相关文章
- 关于android编程中service和activity的区别
一. 绝大部分情况下,Service的作用是用来“执行”后台的.耗时的.重要的任务,三者缺一不可,而最重要的原因是第三点:要执行重要的任务. 因为当一个进程启动了Service后,进程的优先级变高了, ...
- Service 启动Activity
1, 在BroadcastReceiver中启动Activity的问题 * * 如果在BroadcastReceiver的onReceive()方法中如下启动一个Activity * Inten ...
- Android开发 ---ContentProvider数据提供者,Activity和Service就是上下文对象,短信监听器,内容观察者
1.activity_main.xml <?xml version="1.0" encoding="utf-8"?> <LinearLayou ...
- Android—Service与Activity的交互
service-Android的四大组件之一.人称"后台服务"指其本身的运行并不依赖于用户可视的UI界面 实际开发中我们经常需要service和activity之间可以相互传递数据 ...
- Android Service与Activity之间通信的几种方式
在Android中,Activity主要负责前台页面的展示,Service主要负责需要长期运行的任务,所以在我们实际开发中,就会常常遇到Activity与Service之间的通信,我们一般在Activ ...
- Android开发之Service的写法以及与Activity的通信
Service的总结: 1.按运行地点分类: 类别 区别 优点 缺点 应用 本地服务(Local) 该服务依附在主进程上, 服务依附在主进程上而不是独立的进程,这样在一定程度上节约了资源,另外 ...
- Android学习笔记(九)一个例子弄清Service与Activity通信
上一篇博文主要整理了Service的创建.绑定过程,本篇主要整理一下Service与Activity的通信方式.包括在启动一个Service时向它传递数据.怎样改变运行中的Service中得数据和侦听 ...
- Android四大组件应用系列——Activity与Service交互实现APK下载
Servic与Activity相比它没有界面,主要是在后台执行一些任务,Service有两种启动方法startService()和bindService(),startService方式Service ...
- Android开发学习之路-Service和Activity的通信
在很多时候,Service都不仅仅需要在后台运行,还需要和Activity进行通信,或者接受Activity的指挥,如何来实现,来看代码. 定义一个服务 // 创建一个服务,然后在onBind()中返 ...
随机推荐
- ios在SQLite3基本操作
iOS关于sqlite3操作 iPhone中支持通过sqlite3来訪问iPhone本地的数据库. 详细用法例如以下 1:加入开发包libsqlite3.0.dylib 首先是设置项目文件.在项目中加 ...
- uva 11992 为矩阵更新查询段树
http://uva.onlinejudge.org/index.php? option=com_onlinejudge&Itemid=8&page=show_problem& ...
- 产品经理(五岁以下儿童)myVegas Slots排名上升的秘密
myVEGAS Slots于AppStore上排名在今年也就是2月份时候飙升,那么什么情况导致这个现象的呢,我们试图通过App Annie的分析给出答案. 上面是myVegas的排名情况,我们能够看到 ...
- REST API 基于ACCESS TOKEN
REST API 基于ACCESS TOKEN 的权限解决方案 REST 设计原则是statelessness的,而且但客户端是APP时,从APP发起的请求,不是基于bowers,无法带相同的se ...
- 【SICP读书笔记(一)】正则序展开的特殊情况
scheme解释器有两种实现方式,一种是应用序,先对每个参数求值,再以首过程对所有求得的参数求值. 第二种是正则序,会“完全展开然后归约”(书中原文) SICP中的练习1.5,让我困惑了一下.原题如下 ...
- 20140719中国互联网公司市值排名TOP20
近期在找工作.关注了一下中国互联网公司的市值,实际情况跟想象的区别非常大. 比方异军突起的小米.京东.唯品会.聚美优品. 比方乐视网由于政策原因,市值两日缩水10亿$.停牌了. 搜房网市值90天蒸发3 ...
- Android Stuido怎样查看快捷键冲突?
看了这篇文章Android Studio怎样查看资源或者函数在哪些类中被引用.知道了快捷键失效的原因,当中有一个原因就是快捷键冲突.那怎样查看快捷键哪些项冲突了呢? Android Studio要查看 ...
- 【iOS发展-61】更换plist经过资源,执行iOS一旦数据仍显示在模拟器的外观,如何解决?
(1)案例介绍 --我们首先导入plist文件做项目,模拟的观看效果. --删除plist,更换一个新的plist,CMD+R模拟执行,或者找到该程序界面上显示最后一个数据. (2)原因 是由于第一次 ...
- HDU 4391 Paint The Wall 段树(水
意甲冠军: 特定n多头排列.m操作 以下是各点的颜色 以下m一种操纵: 1 l r col 染色 2 l r col 问间隔col色点 == 通的操作+区间内最大最小颜色数的优化,感觉非常不科学... ...
- mybatis 并发问题解决,参考hibernate
时候操作同一账户就是典型的样例. 比方A.B操作员同一时候读取一剩余金额为1000元的账户,A操作员为该账户添加100元.B操作员同一时候为该账户减去 50元.A先提交.B后提交. 最后实际账户剩余金 ...