- 浏览: 12134 次
- 性别:
- 来自: 苏州
文章分类
最新评论
Android Service生命周期及用法
Service概念及用途:
Android中的服务,它与Activity不同,它是不能与用户交互的,不能自己启动的,运行在后台的程序,如果我们退出应用时,Service进程并没有结束,它仍然在后台运行,那 我们什么时候会用到Service呢?比如我们播放音乐的时候,有可能想边听音乐边干些其他事情,当我们退出播放音乐的应用,如果不用Service,我 们就听不到歌了,所以这时候就得用到Service了,又比如当我们一个应用的数据是通过网络获取的,不同时间(一段时间)的数据是不同的这时候我们可以 用Service在后台定时更新,而不用每打开应用的时候在去获取。
Service生命周期 :
Android Service的生命周期并不像Activity那么复杂,它只继承了onCreate(),onStart(),onDestroy()三个方法,当我们第一次启动Service时,先后调用了onCreate(),onStart()这两个方法,当停止Service时,则执行onDestroy()方法,这里需要注意的是,如果Service已经启动了,当我们再次启动Service时,不会在执行onCreate()方法,而是直接执行onStart()方法,具体的可以看下面的实例。
Service与Activity通信:
Service后端的数据最终还是要呈现在前端Activity之上的,因为启动Service时,系统会重新开启一个新的进程,这就涉及到不同进程间通信的问题了(AIDL)这一节我不作过多描述,当我们想获取启动的Service实例时,我们可以用到bindService和onBindService方法,它们分别执行了Service中IBinder()和onUnbind()方法。
为了让大家 更容易理解,我写了一个简单的Demo,大家可以模仿着我,一步一步的来。
第一步:新建一个Android工程,我这里命名为ServiceDemo.
第二步:修改main.xml代码,我这里增加了四个按钮,代码如下:
view plain§copy to clipboard§print§?§
1<?xml version="1.0" encoding="utf-8"?>
2<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
3 android:orientation="vertical"
4 android:layout_width="fill_parent"
5 android:layout_height="fill_parent"
6 >
7 <TextView
8 android:id="@+id/text"
9 android:layout_width="fill_parent"
10 android:layout_height="wrap_content"
11 android:text="@string/hello"
12 />
13 <Button
14 android:id="@+id/startservice"
15 android:layout_width="fill_parent"
16 android:layout_height="wrap_content"
17 android:text="startService"
18 />
19 <Button
20 android:id="@+id/stopservice"
21 android:layout_width="fill_parent"
22 android:layout_height="wrap_content"
23 android:text="stopService"
24 />
25 <Button
26 android:id="@+id/bindservice"
27 android:layout_width="fill_parent"
28 android:layout_height="wrap_content"
29 android:text="bindService"
30 />
31 <Button
32 android:id="@+id/unbindservice"
33 android:layout_width="fill_parent"
34 android:layout_height="wrap_content"
35 android:text="unbindService"
36 />
37</LinearLayout>
第三步:新建一个Service,命名为MyService.java代码如下:
view plain§copy to clipboard§print§?§
38package com.tutor.servicedemo;
39import android.app.Service;
40import android.content.Intent;
41import android.os.Binder;
42import android.os.IBinder;
43import android.text.format.Time;
44import android.util.Log;
45public class MyService extends Service {
46 //定义个一个Tag标签
47 private static final String TAG = "MyService";
48 //这里定义吧一个Binder类,用在onBind()有方法里,这样Activity那边可以获取到
49 private MyBinder mBinder = new MyBinder();
50 @Override
51 public IBinder onBind(Intent intent) {
52 Log.e(TAG, "start IBinder~~~");
53 return mBinder;
54 }
55 @Override
56 public void onCreate() {
57 Log.e(TAG, "start onCreate~~~");
58 super.onCreate();
59 }
60
61 @Override
62 public void onStart(Intent intent, int startId) {
63 Log.e(TAG, "start onStart~~~");
64 super.onStart(intent, startId);
65 }
66
67 @Override
68 public void onDestroy() {
69 Log.e(TAG, "start onDestroy~~~");
70 super.onDestroy();
71 }
72
73
74 @Override
75 public boolean onUnbind(Intent intent) {
76 Log.e(TAG, "start onUnbind~~~");
77 return super.onUnbind(intent);
78 }
79
80 //这里我写了一个获取当前时间的函数,不过没有格式化就先这么着吧
81 public String getSystemTime(){
82
83 Time t = new Time();
84 t.setToNow();
85 return t.toString();
86 }
87
88 public class MyBinder extends Binder{
89 MyService getService()
90 {
91 return MyService.this;
92 }
93 }
94}
第四步:修改ServiceDemo.java,代码如下:
view plain§copy to clipboard§print§?§
95package com.tutor.servicedemo;
96import android.app.Activity;
97import android.content.ComponentName;
98import android.content.Context;
99import android.content.Intent;
100import android.content.ServiceConnection;
101import android.os.Bundle;
102import android.os.IBinder;
103import android.view.View;
104import android.view.View.OnClickListener;
105import android.widget.Button;
106import android.widget.TextView;
107public class ServiceDemo extends Activity implements OnClickListener{
108
109 private MyService mMyService;
110 private TextView mTextView;
111 private Button startServiceButton;
112 private Button stopServiceButton;
113 private Button bindServiceButton;
114 private Button unbindServiceButton;
115 private Context mContext;
116
117 //这里需要用到ServiceConnection在Context.bindService和context.unBindService()里用到
118 private ServiceConnection mServiceConnection = new ServiceConnection() {
119 //当我bindService时,让TextView显示MyService里getSystemTime()方法的返回值
120 public void onServiceConnected(ComponentName name, IBinder service) {
121 // TODO Auto-generated method stub
122 mMyService = ((MyService.MyBinder)service).getService();
123 mTextView.setText("I am frome Service :" + mMyService.getSystemTime());
124 }
125
126 public void onServiceDisconnected(ComponentName name) {
127 // TODO Auto-generated method stub
128
129 }
130 };
131 public void onCreate(Bundle savedInstanceState) {
132 super.onCreate(savedInstanceState);
133 setContentView(R.layout.main);
134 setupViews();
135 }
136
137 public void setupViews(){
138
139 mContext = ServiceDemo.this;
140 mTextView = (TextView)findViewById(R.id.text);
141
142
143
144 startServiceButton = (Button)findViewById(R.id.startservice);
145 stopServiceButton = (Button)findViewById(R.id.stopservice);
146 bindServiceButton = (Button)findViewById(R.id.bindservice);
147 unbindServiceButton = (Button)findViewById(R.id.unbindservice);
148
149 startServiceButton.setOnClickListener(this);
150 stopServiceButton.setOnClickListener(this);
151 bindServiceButton.setOnClickListener(this);
152 unbindServiceButton.setOnClickListener(this);
153 }
154
155 public void onClick(View v) {
156 // TODO Auto-generated method stub
157 if(v == startServiceButton){
158 Intent i = new Intent();
159 i.setClass(ServiceDemo.this, MyService.class);
160 mContext.startService(i);
161 }else if(v == stopServiceButton){
162 Intent i = new Intent();
163 i.setClass(ServiceDemo.this, MyService.class);
164 mContext.stopService(i);
165 }else if(v == bindServiceButton){
166 Intent i = new Intent();
167 i.setClass(ServiceDemo.this, MyService.class);
168 mContext.bindService(i, mServiceConnection, BIND_AUTO_CREATE);
169 }else{
170 mContext.unbindService(mServiceConnection);
171 }
172 }
173
174
175
176}
第五步:修改AndroidManifest.xml代码(将我们新建的MyService注册进去如下代码第14行:)
view plain§copy to clipboard§print§?§
177<?xml version="1.0" encoding="utf-8"?>
178<manifest xmlns:android="http://schemas.android.com/apk/res/android"
179 package="com.tutor.servicedemo"
180 android:versionCode="1"
181 android:versionName="1.0">
182 <application android:icon="@drawable/icon" android:label="@string/app_name">
183 <activity android:name=".ServiceDemo"
184 android:label="@string/app_name">
185 <intent-filter>
186 <action android:name="android.intent.action.MAIN" />
187 <category android:name="android.intent.category.LAUNCHER" />
188 </intent-filter>
189 </activity>
190 <service android:name=".MyService" android:exported="true"></service>
191 </application>
192 <uses-sdk android:minSdkVersion="7" />
193</manifest>
第六步:执行上述工程
点击startServie按钮时先后执行了Service中onCreate()->onStart()这两个方法,打开Logcat视窗效果如下图:
我们这时可以按HOME键进入Settings(设置)->Applications(应用)->Running Services(正在运行的服务)看一下我们新启动了一个服务
点击stopService按钮时,Service则执行了onDestroy()方法
这时候我们再次点击startService按钮,然后点击bindService按钮(通常bindService都是bind已经启动的Service),我们看一下Service执行了IBinder()方法,以及TextView的值也有所变化了
最后点击unbindService按钮,则Service执行了onUnbind()方法
Service概念及用途:
Android中的服务,它与Activity不同,它是不能与用户交互的,不能自己启动的,运行在后台的程序,如果我们退出应用时,Service进程并没有结束,它仍然在后台运行,那 我们什么时候会用到Service呢?比如我们播放音乐的时候,有可能想边听音乐边干些其他事情,当我们退出播放音乐的应用,如果不用Service,我 们就听不到歌了,所以这时候就得用到Service了,又比如当我们一个应用的数据是通过网络获取的,不同时间(一段时间)的数据是不同的这时候我们可以 用Service在后台定时更新,而不用每打开应用的时候在去获取。
Service生命周期 :
Android Service的生命周期并不像Activity那么复杂,它只继承了onCreate(),onStart(),onDestroy()三个方法,当我们第一次启动Service时,先后调用了onCreate(),onStart()这两个方法,当停止Service时,则执行onDestroy()方法,这里需要注意的是,如果Service已经启动了,当我们再次启动Service时,不会在执行onCreate()方法,而是直接执行onStart()方法,具体的可以看下面的实例。
Service与Activity通信:
Service后端的数据最终还是要呈现在前端Activity之上的,因为启动Service时,系统会重新开启一个新的进程,这就涉及到不同进程间通信的问题了(AIDL)这一节我不作过多描述,当我们想获取启动的Service实例时,我们可以用到bindService和onBindService方法,它们分别执行了Service中IBinder()和onUnbind()方法。
为了让大家 更容易理解,我写了一个简单的Demo,大家可以模仿着我,一步一步的来。
第一步:新建一个Android工程,我这里命名为ServiceDemo.
第二步:修改main.xml代码,我这里增加了四个按钮,代码如下:
view plain§copy to clipboard§print§?§
1<?xml version="1.0" encoding="utf-8"?>
2<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
3 android:orientation="vertical"
4 android:layout_width="fill_parent"
5 android:layout_height="fill_parent"
6 >
7 <TextView
8 android:id="@+id/text"
9 android:layout_width="fill_parent"
10 android:layout_height="wrap_content"
11 android:text="@string/hello"
12 />
13 <Button
14 android:id="@+id/startservice"
15 android:layout_width="fill_parent"
16 android:layout_height="wrap_content"
17 android:text="startService"
18 />
19 <Button
20 android:id="@+id/stopservice"
21 android:layout_width="fill_parent"
22 android:layout_height="wrap_content"
23 android:text="stopService"
24 />
25 <Button
26 android:id="@+id/bindservice"
27 android:layout_width="fill_parent"
28 android:layout_height="wrap_content"
29 android:text="bindService"
30 />
31 <Button
32 android:id="@+id/unbindservice"
33 android:layout_width="fill_parent"
34 android:layout_height="wrap_content"
35 android:text="unbindService"
36 />
37</LinearLayout>
第三步:新建一个Service,命名为MyService.java代码如下:
view plain§copy to clipboard§print§?§
38package com.tutor.servicedemo;
39import android.app.Service;
40import android.content.Intent;
41import android.os.Binder;
42import android.os.IBinder;
43import android.text.format.Time;
44import android.util.Log;
45public class MyService extends Service {
46 //定义个一个Tag标签
47 private static final String TAG = "MyService";
48 //这里定义吧一个Binder类,用在onBind()有方法里,这样Activity那边可以获取到
49 private MyBinder mBinder = new MyBinder();
50 @Override
51 public IBinder onBind(Intent intent) {
52 Log.e(TAG, "start IBinder~~~");
53 return mBinder;
54 }
55 @Override
56 public void onCreate() {
57 Log.e(TAG, "start onCreate~~~");
58 super.onCreate();
59 }
60
61 @Override
62 public void onStart(Intent intent, int startId) {
63 Log.e(TAG, "start onStart~~~");
64 super.onStart(intent, startId);
65 }
66
67 @Override
68 public void onDestroy() {
69 Log.e(TAG, "start onDestroy~~~");
70 super.onDestroy();
71 }
72
73
74 @Override
75 public boolean onUnbind(Intent intent) {
76 Log.e(TAG, "start onUnbind~~~");
77 return super.onUnbind(intent);
78 }
79
80 //这里我写了一个获取当前时间的函数,不过没有格式化就先这么着吧
81 public String getSystemTime(){
82
83 Time t = new Time();
84 t.setToNow();
85 return t.toString();
86 }
87
88 public class MyBinder extends Binder{
89 MyService getService()
90 {
91 return MyService.this;
92 }
93 }
94}
第四步:修改ServiceDemo.java,代码如下:
view plain§copy to clipboard§print§?§
95package com.tutor.servicedemo;
96import android.app.Activity;
97import android.content.ComponentName;
98import android.content.Context;
99import android.content.Intent;
100import android.content.ServiceConnection;
101import android.os.Bundle;
102import android.os.IBinder;
103import android.view.View;
104import android.view.View.OnClickListener;
105import android.widget.Button;
106import android.widget.TextView;
107public class ServiceDemo extends Activity implements OnClickListener{
108
109 private MyService mMyService;
110 private TextView mTextView;
111 private Button startServiceButton;
112 private Button stopServiceButton;
113 private Button bindServiceButton;
114 private Button unbindServiceButton;
115 private Context mContext;
116
117 //这里需要用到ServiceConnection在Context.bindService和context.unBindService()里用到
118 private ServiceConnection mServiceConnection = new ServiceConnection() {
119 //当我bindService时,让TextView显示MyService里getSystemTime()方法的返回值
120 public void onServiceConnected(ComponentName name, IBinder service) {
121 // TODO Auto-generated method stub
122 mMyService = ((MyService.MyBinder)service).getService();
123 mTextView.setText("I am frome Service :" + mMyService.getSystemTime());
124 }
125
126 public void onServiceDisconnected(ComponentName name) {
127 // TODO Auto-generated method stub
128
129 }
130 };
131 public void onCreate(Bundle savedInstanceState) {
132 super.onCreate(savedInstanceState);
133 setContentView(R.layout.main);
134 setupViews();
135 }
136
137 public void setupViews(){
138
139 mContext = ServiceDemo.this;
140 mTextView = (TextView)findViewById(R.id.text);
141
142
143
144 startServiceButton = (Button)findViewById(R.id.startservice);
145 stopServiceButton = (Button)findViewById(R.id.stopservice);
146 bindServiceButton = (Button)findViewById(R.id.bindservice);
147 unbindServiceButton = (Button)findViewById(R.id.unbindservice);
148
149 startServiceButton.setOnClickListener(this);
150 stopServiceButton.setOnClickListener(this);
151 bindServiceButton.setOnClickListener(this);
152 unbindServiceButton.setOnClickListener(this);
153 }
154
155 public void onClick(View v) {
156 // TODO Auto-generated method stub
157 if(v == startServiceButton){
158 Intent i = new Intent();
159 i.setClass(ServiceDemo.this, MyService.class);
160 mContext.startService(i);
161 }else if(v == stopServiceButton){
162 Intent i = new Intent();
163 i.setClass(ServiceDemo.this, MyService.class);
164 mContext.stopService(i);
165 }else if(v == bindServiceButton){
166 Intent i = new Intent();
167 i.setClass(ServiceDemo.this, MyService.class);
168 mContext.bindService(i, mServiceConnection, BIND_AUTO_CREATE);
169 }else{
170 mContext.unbindService(mServiceConnection);
171 }
172 }
173
174
175
176}
第五步:修改AndroidManifest.xml代码(将我们新建的MyService注册进去如下代码第14行:)
view plain§copy to clipboard§print§?§
177<?xml version="1.0" encoding="utf-8"?>
178<manifest xmlns:android="http://schemas.android.com/apk/res/android"
179 package="com.tutor.servicedemo"
180 android:versionCode="1"
181 android:versionName="1.0">
182 <application android:icon="@drawable/icon" android:label="@string/app_name">
183 <activity android:name=".ServiceDemo"
184 android:label="@string/app_name">
185 <intent-filter>
186 <action android:name="android.intent.action.MAIN" />
187 <category android:name="android.intent.category.LAUNCHER" />
188 </intent-filter>
189 </activity>
190 <service android:name=".MyService" android:exported="true"></service>
191 </application>
192 <uses-sdk android:minSdkVersion="7" />
193</manifest>
第六步:执行上述工程
点击startServie按钮时先后执行了Service中onCreate()->onStart()这两个方法,打开Logcat视窗效果如下图:
我们这时可以按HOME键进入Settings(设置)->Applications(应用)->Running Services(正在运行的服务)看一下我们新启动了一个服务
点击stopService按钮时,Service则执行了onDestroy()方法
这时候我们再次点击startService按钮,然后点击bindService按钮(通常bindService都是bind已经启动的Service),我们看一下Service执行了IBinder()方法,以及TextView的值也有所变化了
最后点击unbindService按钮,则Service执行了onUnbind()方法
相关推荐
`onDestroy()`则在Service被停止时调用,标志着Service生命周期的结束。值得注意的是,Service的生命周期管理需要谨慎处理,以避免内存泄漏和不必要的资源消耗。 Service与Activity之间的通信是通过Binder机制实现...
使用`startService()`方法启动Service,这会导致Service生命周期中的`onStartCommand()`被调用。若要停止Service,可以调用`stopService()`。需要注意的是,即使调用了`stopService()`,Service可能并不会立即停止,...
总的来说,Android Service的生命周期管理是开发者必须掌握的关键技能,正确理解和使用Service生命周期能够确保应用的稳定性和效率,避免不必要的资源消耗。在开发过程中,我们还需要注意Service的权限管理,以及在...
本篇将深入探讨Activity和Service的生命周期以及如何利用Android Interface Definition Language (AIDL)进行进程间通信。 Activity是Android应用程序的用户界面,它负责与用户交互。Activity的生命周期分为几个关键...
以下是一个关于Service生命周期的详细解析,结合代码示例来阐述如何在Android中操作Service。 1. **Service生命周期概述** Service的生命周期主要包含以下几个阶段:onCreate()、onStartCommand()、onBind()、...
startService启动方式,只在activity中启动和销毁,和activity关系不大,即使antivity退出,服务任然运行,比如后台放音乐,对应生命周期: bindService启动方式,和activity绑定后,和activity共存亡,activity...
通过在这些方法中添加Log语句或者使用Android Studio的生命周期插件,可以清晰地观察到Activity状态的转换,从而更好地理解每个方法的作用和执行时机。 总的来说,这个“Android生命周期Demo”项目提供了一个实践...
总的来说,Android Service生命周期管理涉及到一系列的回调方法,通过这些方法,开发者能够精确控制服务的启动、运行和终止,同时确保服务在正确的时间释放资源。合理地使用服务能提高应用的效率和用户体验。在实际...
在Service运行过程中,可以利用生命周期方法确保资源的合理使用,例如在`onDestroy()`中释放计算过程中占用的资源。 标签中的“activity”提醒我们Service与Activity之间的通信。Service可以通过Binder、...
- 未绑定Activity的Service生命周期图显示了startService()启动的过程,而绑定Activity的Service生命周期图则展示了bindService()启动的过程,两者在生命周期上有显著差异。 理解并熟练掌握Service的生命周期及其...
Android Activity 生命周期是指 Activity 从创建到销毁的整个过程,该过程中会经历多个状态变化,每个状态变化都会触发相应的回调方法。理解 Activity 生命周期是 Android 开发的基础。 在 Android 中,Activity ...
- **Service生命周期**: - `onCreate()`:Service首次创建时调用。 - `onStartCommand()`或`onBind()`:根据Service类型(启动型或绑定型),在Service启动时调用。 - `onDestroy()`:Service销毁前调用。 - **...
1. **Android Profiler**:可以实时监控Activity的生命周期状态变化,同时分析内存、CPU和网络使用情况。 2. **Logcat**:通过打印日志,可以在控制台跟踪Activity的生命周期回调。 3. **Hierarchy Viewer**(现已...
6. **Service生命周期**: Service的生命周期包括`onCreate()`, `onStartCommand()`, `onBind()`, `onUnbind()`, `onDestroy()`等关键方法。在创建Service时,会调用`onCreate()`,接着如果是通过`startService()`...
总结来说,本演示涵盖了Android开发中的核心知识点,包括Activity的生命周期管理、Service的使用以及UI设计技巧,这些都是构建高效、用户友好的Android应用所必需的技能。通过对"android.test"文件的学习和实践,...
本实验报告将深入探讨Android应用程序,尤其是Activity、Service和Intent Receiver的生命周期,并解释如何正确管理这些组件以避免不必要的进程销毁。 首先,Android应用通常在独立的Linux进程中运行。当应用需要...
总之,Android Service是实现后台操作的重要工具,通过合理的使用和服务生命周期管理,可以为用户提供高效、稳定的后台服务。而 Binder 机制则让Service具备了跨进程通信的能力,极大地扩展了Service的应用场景。...
startService启动方式,只在activity中启动和销毁,和activity关系不大,即使antivity退出,服务任然运行,比如后台放音乐,对应生命周期: bindService启动方式,和activity绑定后,和activity共存亡,activity...
要实现一个有生命周期感知的网络请求框架,我们首先需要配置Retrofit2,定义一个包含所有网络接口的Service类,如`ApiService`,并使用Retrofit.Builder进行构建。接着,我们可以使用RxJava的Observable来包装...
总结来说,Intent是Android组件间通信的核心,它的生命周期与Activity紧密关联。理解和熟练运用Intent对于优化用户体验和提高代码效率至关重要。在开发中,我们应充分利用Intent的特性,实现高效、灵活的组件交互。