Android 面试题之Service干货篇(1)

bindService

  • 1.使用bindService()方法启动Service

绑定模式使用bindService()方法启动Service,其格式如下:

bindService(Intent service,ServiceConnection conn,int flags);

其中的参数说明如下:

  • service:该参数通过Intent指定需要启动的service。

  • conn:该参数是ServiceConnnection对象,当绑定成功后,系统将调用serviceConnnection的onServiceConnected ()方法,当绑定意外断开后,系统将调用ServiceConnnection中的onServiceDisconnected方法。

  • flags:该参数指定绑定时是否自动创建Service。如果指定为BIND_AUTO_CREATE,则自动创建,指定为0,则不自动创建。

绑定方式中,当调用者通过bindService()函数绑定Service时,onCreate()函数和onBinde ( )函数将被先后调用。

「通过该方式启动Service,访问者与Service绑定在一起,访问者一旦退出了,Service也就终止了。」

  • 2.使用unbindService()方法取消绑定

取消绑定仅需要使用unbindService()方法,并将ServiceConnnection传递给unbindService()方法。

但需要注意的是,unbindService()方法成功后,系统并不会调用onServiceConnected(),因为onServiceConnected()仅在意外断开绑定时才被调用。

当调用者通过unbindService()函数取消绑定Service时,onUnbind()函数将被调用。如果onUnbind()函数返回true,则表示重新绑定服务时,onRebind ()函数将被调用。

startService样例

  • 1.创建StartService.java继承自Service类,重写onCreate()方法、onStartCommand()方法、onBind()方法、onDestroy()方法,其代码如下:

public class StartService extends Service {

@Override

public void onCreate() {

super.onCreate();

MLog.e(getClass().getName(), “onCreate”);

}

@Override

public int onStartCommand(Intent intent, int flags, int startId) {

MLog.e(getClass().getName(), “onStartCommand”);

return super.onStartCommand(intent, flags, startId);

}

@Override

public void onDestroy() {

MLog.e(getClass().getName(), “onDestroy”);

super.onDestroy();

}

@Nullable

@Override

public IBinder onBind(Intent intent) {

return null;

}

}

  • 2.创建ServiceActivity.java和配套的activity_service.xml文件,其代码如下:

public class ServiceActivity extends ActivityBase {

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_service);

Intent intentStart = new Intent(ServiceActivity.this, StartService.class);

findViewById(R.id.btn_start).setOnClickListener(new View.OnClickListener() {

@Override

public void onClick(View v) {

startService(intentStart);

}

});

findViewById(R.id.btn_stop).setOnClickListener(new View.OnClickListener() {

@Override

public void onClick(View v) {

stopService(intentStart);

}

});

}

}

  • 配套的activity_service.xml文件
<?xml version="1.0" encoding="utf-8"?>

<LinearLayout xmlns:android=“http://schemas.android.com/apk/res/android”

android:id=“@+id/ll_bg”

android:layout_width=“match_parent”

android:layout_height=“match_parent”

android:orientation=“vertical”

android:background=“@color/color_666666”>

<Button

android:id=“@+id/btn_start”

android:layout_width=“wrap_content”

android:layout_height=“wrap_content”

android:text=“start启动服务”/>

<Button

android:id=“@+id/btn_stop”

android:layout_width=“wrap_content”

android:layout_height=“wrap_content”

android:text=“start停止服务”/>

  • 3.添加Service组件声明,在AndroidManifest.xml文件中声明一个Service组件,其代码如下:
<?xml version="1.0" encoding="utf-8"?>

<manifest xmlns:android=“http://schemas.android.com/apk/res/android”

package=“com.scc.demo”>

<application

…>

<activity

…>

  • 运行结果

07-07 16:41:11.474 E/-SCC-: com.scc.demo.actvitiy.ServiceActivityonCreate

07-07 16:41:11.481 E/-SCC-: com.scc.demo.actvitiy.ServiceActivityonStart

07-07 16:41:11.482 E/-SCC-: com.scc.demo.actvitiy.ServiceActivityonResume

07-07 16:41:13.313 E/-SCC-com.scc.demo.service.StartService: onCreate

07-07 16:41:13.334 E/-SCC-com.scc.demo.service.StartService: onStartCommand

07-07 16:41:16.705 E/-SCC-com.scc.demo.service.StartService: onDestroy

bindService样例

  • 1.创建BindService.java继承自Service类,重写onCreate()方法、onBind()方法、onUnbind()方法、onDestroy()方法,实现本地通知栏显示,其代码如下:

public class BindService extends Service {

//声明IBinder接口的一个接口变量mBinder

public final IBinder mBinder = new LocalBinder();

private NotificationManager mNM;

private int NOTIFICATION = R.string.local_service_started;

//LocalBinder是继承Binder的一个内部类

public class LocalBinder extends Binder {

public BindService getService() {

return BindService.this;

}

}

@Override

public void onCreate() {

mNM = (NotificationManager)getSystemService(NOTIFICATION_SERVICE);

MLog.e(getClass().getName(), “onCreate”);

showNotification();

}

@Override

public void onDestroy() {

MLog.e(getClass().getName(), “onDestroy”);

mNM.cancel(NOTIFICATION);

Toast.makeText(this, R.string.local_service_stopped, Toast.LENGTH_SHORT).show();

}

@Override

public IBinder onBind(Intent intent) {

MLog.e(getClass().getName(), “onBind”);

return mBinder;

}

@Override

public boolean onUnbind(Intent intent) {

MLog.e(getClass().getName(), “onUnbind”);

return super.onUnbind(intent);

}

private void showNotification() {

CharSequence text = getText(R.string.local_service_started);

PendingIntent contentIntent = PendingIntent.getActivity(this, 0,

new Intent(this, ServiceActivity.class), 0);

Notification notification = new Notification.Builder(this)

.setSmallIcon(R.mipmap.ic_launcher)

.setTicker(text)

.setWhen(System.currentTimeMillis())

.setContentTitle(getText(R.string.local_service_label))

.setContentText(text)

.setContentIntent(contentIntent)

.build();

mNM.notify(NOTIFICATION, notification);

MLog.e(getClass().getName(), “通知栏已出”);

}

}

  • 2.创建ServiceActivity.java和配套的activity_service.xml文件,其代码如下:

public class ServiceActivity extends ActivityBase {

private BindService bindService;

private boolean isBind = false;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_service);

findViewById(R.id.btn_bind).setOnClickListener(new View.OnClickListener() {

@Override

public void onClick(View v) {

if (!isBind) {

Intent intentBind = new Intent(ServiceActivity.this, BindService.class);

bindService(intentBind, serviceConnection, Context.BIND_AUTO_CREATE);

isBind = true;

}

}

});

findViewById(R.id.btn_unbing).setOnClickListener(new View.OnClickListener() {

@Override

public void onClick(View v) {

if (isBind) {

isBind = false;

unbindService(serviceConnection);

bindService = null;

}

}

});

}

private ServiceConnection serviceConnection = new ServiceConnection() {

@Override

public void onServiceConnected(ComponentName name, IBinder service) {

MLog.e(getClass().getName(), “onServiceConnected”);

bindService = ((BindService.LocalBinder) service).getService();

}

@Override

public void onServiceDisconnected(ComponentName name) {

MLog.e(getClass().getName(), “onServiceDisconnected”);

bindService = null;

}

};

}

  • 配套的activity_service.xml文件
<?xml version="1.0" encoding="utf-8"?>

<LinearLayout xmlns:android=“http://schemas.android.com/apk/res/android”

android:id=“@+id/ll_bg”

android:layout_width=“match_parent”

android:layout_height=“match_parent”

android:orientation=“vertical”

android:background=“@color/color_666666”>

<Button

android:id=“@+id/btn_bind”

android:layout_width=“wrap_content”

android:layout_height=“wrap_content”

android:text=“bind服务绑定”/>

<Button

android:id=“@+id/btn_unbing”

android:layout_width=“wrap_content”

android:layout_height=“wrap_content”

android:text=“bind解除绑定”/>

  • 3.添加Service组件声明,在AndroidManifest.xml文件中声明一个Service组件,其代码如下:
<?xml version="1.0" encoding="utf-8"?>

<manifest xmlns:android=“http://schemas.android.com/apk/res/android”

package=“com.scc.demo”>

<application

…>

<activity

…>

  • 4运行结果

07-07 17:00:04.309 E/-SCC-: com.scc.demo.actvitiy.ServiceActivityonCreate

07-07 17:00:04.350 E/-SCC-: com.scc.demo.actvitiy.ServiceActivityonStart

07-07 17:00:04.350 E/-SCC-: com.scc.demo.actvitiy.ServiceActivityonResume

07-07 17:00:10.088 E/-SCC-com.scc.demo.service.BindService: onCreate

07-07 17:00:10.120 E/-SCC-com.scc.demo.service.BindService: 通知栏已出

07-07 17:00:10.145 E/-SCC-com.scc.demo.service.BindService: onBind

07-07 17:00:10.164 E/-SCC-com.scc.demo.actvitiy.ServiceActivity$5: onServiceConnected

07-07 17:00:39.111 E/-SCC-com.scc.demo.service.BindService: onUnbind

07-07 17:00:39.134 E/-SCC-com.scc.demo.service.BindService: onDestroy

三、Service生命周期


service

「onBind()」 是Service必须实现的方法,返回的IBinder对象相当于Service组件的代理对象,Service允许其他程序组件通过IBinder对象来访问Service内部数据,这样即可实现其他程序组件与Service之间的通信。

startService启动的生命周期

「onCreate()」 当Service第一次被创建时,由系统调用。

「onStartCommand()」 当startService方法启动Service时,该方法被调用。

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)

学习福利

【Android 详细知识点思维脑图(技能树)】

其实Android开发的知识点就那么多,面试问来问去还是那么点东西。所以面试没有其他的诀窍,只看你对这些知识点准备的充分程度。so,出去面试时先看看自己复习到了哪个阶段就好。

虽然 Android 没有前几年火热了,已经过去了会四大组件就能找到高薪职位的时代了。这只能说明 Android 中级以下的岗位饱和了,现在高级工程师还是比较缺少的,很多高级职位给的薪资真的特别高(钱多也不一定能找到合适的),所以努力让自己成为高级工程师才是最重要的。

这里附上上述的面试题相关的几十套字节跳动,京东,小米,腾讯、头条、阿里、美团等公司19年的面试题。把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节。

由于篇幅有限,这里以图片的形式给大家展示一小部分。

网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

习福利

【Android 详细知识点思维脑图(技能树)】

[外链图片转存中…(img-i8GAGNZC-1713771523980)]

其实Android开发的知识点就那么多,面试问来问去还是那么点东西。所以面试没有其他的诀窍,只看你对这些知识点准备的充分程度。so,出去面试时先看看自己复习到了哪个阶段就好。

虽然 Android 没有前几年火热了,已经过去了会四大组件就能找到高薪职位的时代了。这只能说明 Android 中级以下的岗位饱和了,现在高级工程师还是比较缺少的,很多高级职位给的薪资真的特别高(钱多也不一定能找到合适的),所以努力让自己成为高级工程师才是最重要的。

这里附上上述的面试题相关的几十套字节跳动,京东,小米,腾讯、头条、阿里、美团等公司19年的面试题。把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节。

由于篇幅有限,这里以图片的形式给大家展示一小部分。

[外链图片转存中…(img-51BQAgUC-1713771523981)]

网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值