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()中返 ...
随机推荐
- hadoop-1.1.2 在Windows环境下的部署
1:先安装Cygwin 参考http://blog.csdn.net/wind520/article/details/9223003 2:下载 3:解压在C:\cygwin\hadoop1 4:配置 ...
- cheese desktop内容
#!/usr/bin/env xdg-open [Desktop Entry] Encoding=UTF- Version=1.0 Type=Application Terminal=false Na ...
- [ACM] HDU 3395 Special Fish (最大重量二分图匹配,KM算法)
Special Fish Problem Description There is a kind of special fish in the East Lake where is closed to ...
- Android菜鸟的成长笔记(15)—— Android中的状态保存探究(下)
原文:Android菜鸟的成长笔记(15)-- Android中的状态保存探究(下) 在上一篇中我们简单了解关于Android中状态保存的过程和原理,这一篇中我们来看一下在系统配置改变的情况下保存数据 ...
- Cocos2d-x学习笔记(9)(CCTextFieldTTF使用输入框)
1.CCTextFieldTTF创建和使用 CCTextFieldTTF::create(const char* placeholder,const char* fontName.float font ...
- 流动python - 什么是魔术方法(magic method)
我们经常看到各种各样的方法已经被包围了由双下划线,例如__init__,他们是魔术方法. 魔术方法python语言预订好"协议",在不同情况下不同的魔术方法,是隐式调用.我们重写这 ...
- MySQL InnoDB数据库备份与还原
备份 进入cm黑窗口 输入下列命令 mysqldump -u 用户名 -p 数据库名称> c:\11.sql 回车执行 恢复 进入cm黑窗口 输入下列命令 mysql>use dbtest ...
- asp.net弹出层实例
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Default.aspx.c ...
- 玩转Web之Jsp(一)-----jsp中的静态包含(<%@include file="url"%>)与动态包含(<jsp:include>)
在jsp中include有两种形式,其中<%@include file="url"%>是指令元素,<jsp:include page="" f ...
- leetcode:pascal's_triangle_II
一. 称号 一行值. 二. 分析 这道题跟Pascal'sTriangle非常类似,仅仅是这里仅仅须要求出某一行的结果.Pascal's Triangle中由于是求出所有结果,所以我们 ...