`
wqkerry
  • 浏览: 13586 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

关于 android service 和 thread

阅读更多

在安卓系统中,service是运行在主线程中的,而thread是用来创建子线程的。二者毫无关系! thread的运行时独立于activity的,当一个activity被销毁时,如果你没有主动停止 Thread 或者 Thread 里的 run 方法没有执行完毕的话,Thread 也会一直执行。当 Activity 被 finish 之后,你不再持有该 Thread 的引用。另一方面,你没有办法在不同的 Activity 中对同一 Thread 进行控制。 但是service却不同,当一个activity被销毁时,另外的activity还可以对service进行控制。因为任何 Activity 都可以控制同一 Service,而系统也只会创建一个对应 Service 的实例。因此可以把 Service 想象成一种消息服务,而你可以在任何有 Context 的地方调用 Context.startService、Context.stopService、 Context.bindService,Context.unbindService,来控制它,你也可以在 Service 里注册 BroadcastReceiver,在其他地方通过发送 broadcast 来控制它,当然这些都是 Thread 做不到的。

 

service

       Service的生命周期方法比Activity少一些,只有onCreate, onStart(onStartCommand), onDestroy

  我们有两种方式启动一个Service,他们对Service生命周期的影响是不一样的。

 

      1.通过startService启动

       Service会经历 onCreate --> onStart(onStartCommand)

  stopService的时候直接onDestroy

  如果是 调用者 直接退出而没有调用stopService的话,Service会一直在后台运行。

  下次调用者再起来仍然可以stopService。

     

      2.通过bindService启动

       Service只会运行onCreate, 这个时候 调用者和Service绑定在一起

  调用者退出了,Srevice就会调用onUnbind-->onDestroyed

  所谓绑定在一起就共存亡了。

     一个bindService启动的例子:

     ServiceDemo.java

   

public class ServiceDemo extends Activity {
	Button btnBind, btnUnBind, btnGetServiceStatus;
	BindService bindService;
	LocalService localService;
	private boolean isBind = false;

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.main);
		btnBind = (Button) findViewById(R.id.btnBind);
		btnUnBind = (Button) findViewById(R.id.btnUnBind);
		btnGetServiceStatus = (Button) findViewById(R.id.btnGetServiceStatus);
		OnClickListener listener = new OnClickListener() {
			@Override
			public void onClick(View v) {
				// TODO Auto-generated method stub
				switch (v.getId()) {
				case R.id.btnBind:
					// Intent intent = new Intent();
					// // 隐式启动Service
					// intent.setAction("com.wang.servicedemo.BIND_SERVICE");
					// 显示启动Service
					Intent intent = new Intent(ServiceDemo.this,
							BindService.class);
					// 绑定指定的Service
					bindService(intent, serviceConnection, BIND_AUTO_CREATE);
					isBind = true;
					break;
				case R.id.btnUnBind:
					if (isBind) {
						// 解除绑定Service,一般要是没有主动去解绑的话,可以在onDestory方法中解绑
						unbindService(serviceConnection);
						isBind = false;
						bindService = null;
						Toast.makeText(ServiceDemo.this,
								"--Service is Unbind.--", Toast.LENGTH_LONG)
								.show();
					} else {
						Toast.makeText(ServiceDemo.this, "--你还未绑定Service--",
								Toast.LENGTH_LONG).show();
					}
					break;
				case R.id.btnGetServiceStatus:
					if (bindService == null) {
						Toast.makeText(ServiceDemo.this, "请先绑定Service",
								Toast.LENGTH_LONG).show();
					} else {
						Toast.makeText(
								ServiceDemo.this,
								"App name:" + bindService.getDemoName()
										+ "\n count:" + localService.getCount(),
								Toast.LENGTH_LONG).show();
						// localService.getService().MyMethod();
					}
					break;
				}
			}
		};
		btnBind.setOnClickListener(listener);
		btnGetServiceStatus.setOnClickListener(listener);
		btnUnBind.setOnClickListener(listener);
	}

	/**
	 * 定义一个ServiceConnection对象, 实例化ServiceConnection接口的实现类,
	 * 重写onServiceConnected()和onServiceDisconnected()方法
	 */
	private ServiceConnection serviceConnection = new ServiceConnection() {
		// 当Activity与Service通过非UnBind()方法断开连接的时候回调该方法
		@Override
		public void onServiceDisconnected(ComponentName name) {
			bindService = null;
			Toast.makeText(ServiceDemo.this, "--Service UnConnected.--",
					Toast.LENGTH_LONG).show();
		}

		// 当Activity与Service连接成功的时候回调该方法
		@Override
		public void onServiceConnected(ComponentName name, IBinder service) {
			// 获取getService()方法返回的BindService对象
			localService = ((LocalService) service);
			bindService = localService.getService();
			bindService.MyMethod();
			Toast.makeText(ServiceDemo.this, "--Service Connected.--",
					Toast.LENGTH_LONG).show();
			System.out.println("--Service Connected.--");
		}
	};
}

 

        BindService.java

public class BindService extends Service {
	private int count = 0;
	private boolean isQuit = false;
	// 定义getService方法返回的对象
	public LocalService localService = new LocalService();

	/*
	 * 创建Binder子类,Binder实现了IBinder接口, 这是一个内部类
	 */
	public class LocalService extends Binder {
		public int getCount() {
			return count;
		}

		public BindService getService() {
			return BindService.this;
		}
	}

	/*
	 * Service子类必须实现的方法,绑定该Service时回调的方法; onbind方法只被调用一次,在第一个client或调用者
	 * 绑定至其的时候被调用。 返回的是Binder对象。 然后其他组件可以通过这个Binder 对象与该service 进行通讯。
	 */
	@Override
	public IBinder onBind(Intent intent) {
		// TODO Auto-generated method stub
		return localService;
	}

	/*
	 * (non-Javadoc) 此方法只执行一次,当service再次被调用时,会执行onStartCommand方法
	 * 
	 * @see android.app.Service#onCreate()
	 */
	@Override
	public void onCreate() {
		// TODO Auto-generated method stub
		System.out.println("Service is Created.");
		// 创建并启动一个线程,动态修改count变量值
		new Thread() {
			@Override
			public void run() {
				// TODO Auto-generated method stub
				while (!isQuit) {
					try {
						Thread.sleep(1000);// 使得当前线程休眠1000毫秒
					} catch (InterruptedException e) {
						// TODO Auto-generated catch block
						e.printStackTrace();
					}
					count++;
				}
			}
		}.start();
		super.onCreate();
	}

	/*
	 * (non-Javadoc)onStart方法已被onStartCommand方法代替,api不赞成使用
	 * 
	 * @see android.app.Service#onStart(android.content.Intent, int)
	 */
	@Override
	@Deprecated
	public void onStart(Intent intent, int startId) {
		// TODO Auto-generated method stub
		super.onStart(intent, startId);
	}

	@Override
	public int onStartCommand(Intent intent, int flags, int startId) {
		// TODO Auto-generated method stub
		return super.onStartCommand(intent, flags, startId);
	}

	// 在所有onUnbind被回调之后调用
	@Override
	public void onDestroy() {
		// TODO Auto-generated method stub
		System.out.println("Service is Destroyed.");
		isQuit = true;
		super.onDestroy();
	}

	// 定义一个返回实例名的方法
	public String getDemoName() {
		return "Service实例";
	}

	// 在所有与Service绑定的客户端都解除绑定之后被回调
	@Override
	public boolean onUnbind(Intent intent) {
		// TODO Auto-generated method stub
		System.out.println("Service is Unbind.");
		return true;// 表示下次客户端绑定的时候接受一个onRebind()的调用(而不是调用 onBind())
	}

	public void MyMethod() {
		for (int i = 0; i < 100; i++) {
			Log.i("44", "BindService-->MyMethod()");
		}
	}

}

 

xml文件:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context="com.wang.servicedemo.MainActivity" >

    <Button
        android:id="@+id/btnBind"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="绑定service" />

    <Button
        android:id="@+id/btnGetServiceStatus"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="获得service状态" />

    <Button
        android:id="@+id/btnUnBind"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="解绑service" />

</LinearLayout>

 

最后在清单文件中声明service:

<service android:name="com.wang.servicedemo.BindService" >
            <intent-filter>

                <!-- 为该Service组件的intent-filter配置action ,用于隐式启动时使用-->
                <action android:name="com.wang.servicedemo.BIND_SERVICE" >
                </action>
            </intent-filter>
        </service>

 

 

 

 

分享到:
评论

相关推荐

    android service toast 01

    Demo android service toast 第一个版本

    android service thread toast handler

    Demo android组件Service与Toast 第二个版本

    Android创建Service后台常驻服务并使用Broadcast通信

    Android创建Service后台常驻服务并使用Broadcast通信,即基于Broadcast通信方式实现了一种Service Thread与Activity异步工作的方法。

    深入剖析Android中Service和Thread区别

    下面小编就为大家带来一篇深入剖析Android中Service和Thread区别。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧

    android 本地service

    本地service回调/thread数据处理/批量处理数据

    测试Service中开启Thread

    测试Service中开启线程修改Activity

    Android底层结构-Service线程详解

    介绍Android Service的文档,用5个例程说明了Service的线程模型,并给出了Android平台上利用binder和service进行进程间通信的示例代码。

    Andriod Service与Thread的区别介绍

    这是因为Activity很难对Thread进行控制,当Activity被销毁之后,就没有任何其它的办法可以再重新获取到之前创建的子线程的实例。而且在一个Activity中创建的子线程,另一个Activity无法对其进行操作。但是Service就...

    Android应用8个后台服务小程序

    Android应用程序开发,8个后台服务相关Demo学习代码;适合刚开始学习Android的Service和Thread的新手

    Android官方api文档完整版+androidstudio快捷键

    Android官方API文档完整版, 内容参考: onBind public final IBinder onBind(Intent intent)从类 Service 复制的描述 Return the communication channel to the service. May return null if clients can not bind ...

    Android-电池管理-实时获取电池电量,温度...等属性。

    实现一个电池属性实时监听器。这些属性包括温度,电池电量.......而且,使用Service,Broadcast,以及Thread的方式来实现。MyBatteryService后台获取Battery属性值,然后,在Activity中进行相关数据的显示。

    Android开发艺术探索

    第11章 Android的线程和线程池 / 391 11.1 主线程和子线程 / 392 11.2 Android中的线程形态 / 392 11.2.1 Async Task / 392 11.2.2 Async Task的工作原理 / 395 11.2.3 Handler Thread / 402 11.2.4 ...

    Android实现定时任务及闹钟

    android中定时有很多种是实现,常见的Handler 与Thread的结合,handler.postDelayed ,以及要使用的AlarmManger 等都可以实现定时任务的执行,但是使用场景却大不相同,这里主要是怎么用AlarmManager实现定时任务。...

    深入理解Android:卷I--详细书签版

     对于Android应用开发工程师而言,本书中关于Binder,以及sp、wp、Handler和Looper等常用类的分析或许能帮助你迅速适应Android平台上的开发工作。  (2)Android系统开发工程师  Android系统开发工程师常常需要...

    Android锁屏无法继续定位问题

    Android锁屏无法继续定位问题 产生问题的原因: 手机锁屏后,Android系统为了省电以及减少CPU消耗,在一段时间后会将手机进入休眠状态。... &lt;service android:name=".MyIntentService"&gt;&lt;/service&gt; 注册

    android9.0ble补丁蓝牙语音遥控器支持补丁.rar

    dev="sysfs" ino=16332 scontext=u:r:hal_audio_default:s0 tcontext=u:object_r:sysfs:s0 tclass=dir permissive=0 //Android 8.0和9.0版本,audio hal被android.hardware.audio@2.0-service进程加载 3、检查audio...

    一本android的好书beginning android 2 和 源码

    以后如果有好的资源,再上传和大家分享。 本资源是第一本。 这是一本学习android的好书,我浏览了,是老外著的,高清晰的pdf。为了方便大家学习android,我将本书所附的源码一块打包了。方便了不少,如果觉得好就...

    《深入理解Android》卷Ⅰ

    6.2.5 秋风扫落叶-StartThread Pool和join Thread Pool分析 6.2.6 你彻底明白了吗 6.3 服务总管ServiceManager 6.3.1 ServiceManager的原理 6.3.2 服务的注册 6.3.3 ServiceManager存在的意义 6.4 ...

    深入理解Android卷1全

    6.2.5 秋风扫落叶-StartThread Pool和join Thread Pool分析 / 149 6.2.6 你彻底明白了吗 / 152 6.3 服务总管ServiceManager / 152 6.3.1 ServiceManager的原理 / 152 6.3.2 服务的注册 / 155 6.3.3 ServiceManager...

Global site tag (gtag.js) - Google Analytics