2024年最全Android 清理后台进程,2024年最新高级测试面试题及答案

资源分享

一线互联网面试专题

379页的Android进阶知识大全

379页的Android进阶知识大全

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

2020年虽然路途坎坷,都在说Android要没落,但是,不要慌,做自己的计划,学自己的习,竞争无处不在,每个行业都是如此。相信自己,没有做不到的,只有想不到的。祝大家2021年万事大吉。

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

getService().killBackgroundProcesses(packageName,

mContext.getUserId());

} catch (RemoteException e) {

throw e.rethrowFromSystemServer();

}

}

源码解释: 让系统立即终止与给定程序包关联的所有后台进程。这与内核杀死那些进程以回收内存的过程相同。系统会在将来根据需要重新启动这些过程。

后台自动清理实现

通过自定义一个服务或者悬浮窗在后台运行,获取当前运行前台运行的包名,用一个集合recentList进行存储,当数量达到多少时执行清理任务

List recentList = new ArrayList<>(10); //后台包名缓存列表

/**

  • 执行桌面后台启动任务清理

  • @author lhw

*/

private synchronized void clearRecentTask() {

Log.w(TAG, “clearRecnetTask recentList==” + recentList.toString());

final ActivityManager am = (ActivityManager) mContext.getSystemService(Context.ACTIVITY_SERVICE);

long beforeMem = getAvailMemory(am);

Log.w(TAG, "-----------before memory info : " + beforeMem);

if (recentList != null && recentList.size() >= 5) {

TaskScheduler.ioHandler().post(new Runnable() {

@Override

public void run() {

int count = 0;

for (int i = 0; i < recentList.size() - 1; i++) {

if (!recentList.get(i).equals(“com.android.systemui”)) {

try {

am.killBackgroundProcesses(recentList.get(i));

recentList.remove(i);

Log.w(TAG, "It will be killed, package name : " + recentList.get(i));

} catch (Exception e) {

Log.e(TAG, "Exception clearMemory killBackgroundProcesses " + e.getMessage());

}

}

count++;

}

Log.w(TAG, "----------- after memory count : " + count);

}

});

}

long afterMem = getAvailMemory(am);

Log.w(TAG, "----------- after memory info : " + afterMem);

}

//获取可用内存大小

private long getAvailMemory(ActivityManager am) {

// 获取android当前可用内存大小

ActivityManager.MemoryInfo mi = new ActivityManager.MemoryInfo();

am.getMemoryInfo(mi);

Log.d(TAG, “可用内存---->>>” + mi.availMem / (1024 * 1024));

return mi.availMem / (1024 * 1024);

}

  • 当前运行App包名获取方式

  • 第一种通过定义一个辅助服务 AccessibilityServiceAccessibilityEventgetPackageName 获取

  • 第二种通过 UsageStatsManager获取当前运行包名,要跳转设置去申请android.permission.PACKAGE_USAGE_STATS权限

public static String getTopPackageName(Context context) {

String topActivityPackageName;

ActivityManager manager = (ActivityManager) context.getSystemService(Context.ACTIVITY_SERVICE);

if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {

final UsageStatsManager mUsageStatsManager = (UsageStatsManager) context.getSystemService(Service.USAGE_STATS_SERVICE);

long endTime = System.currentTimeMillis();

long beginTime = endTime - 60301000; // 1000 * 3;// * 60 * 2;

UsageEvents usageEvents = mUsageStatsManager.queryEvents(beginTime, endTime);

if (usageEvents == null || !usageEvents.hasNextEvent()) {

Log.w(“usageEvents==null”);

return null;

}

ComponentName comp = null;

String pkgName = null;

String clsName = null;

UsageEvents.Event event = new UsageEvents.Event();

long prevTime = 0;

while(usageEvents.getNextEvent(event)) {

if (event.getEventType() == event.MOVE_TO_FOREGROUND) {

if (prevTime == 0 || Long.compare(event.getTimeStamp(), prevTime) > 0) {

pkgName = event.getPackageName();

clsName = event.getClassName();

prevTime = event.getTimeStamp();

}

} else if(event.getEventType() == event.MOVE_TO_BACKGROUND && prevTime != 0) {

pkgName = null;

clsName = null;

}

}

return pkgName;

} else {

List<ActivityManager.RunningTaskInfo> taskInfos = manager.getRunningTasks(1);

if (taskInfos.size() > 0)

topActivityPackageName = taskInfos.get(0).topActivity.getPackageName();

else

return null;

return topActivityPackageName;

}

}

  • forceStopPackage

次方法是系统隐藏的,而且还需要 android.Manifest.permission#FORCE_STOP_PACKAGES 权限

总结

现在新技术层出不穷,如果每次出新的技术,我们都深入的研究的话,很容易分散精力。新的技术可能很久之后我们才会在工作中用得上,当学的新技术无法学以致用,很容易被我们遗忘,到最后真的需要使用的时候,又要从头来过(虽然上手会更快)。

我觉得身为技术人,针对新技术应该是持拥抱态度的,入了这一行你就应该知道这是一个活到老学到老的行业,所以面对新技术,不要抵触,拥抱变化就好了。

Flutter 明显是一种全新的技术,而对于这个新技术在发布之初,花一个月的时间学习它,成本确实过高。但是周末花一天时间体验一下它的开发流程,了解一下它的优缺点、能干什么或者不能干什么。这个时间,并不是我们不能接受的。

如果有时间,其实通读一遍 Flutter 的文档,是最全面的一次对 Flutter 的了解过程。但是如果我们只有 8 小时的时间,我希望能关注一些最值得关注的点。

(跨平台开发(Flutter)、java基础与原理,自定义view、NDK、架构设计、性能优化、完整商业项目开发等)

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

片转存中…(img-47PdYwgv-1715845404217)]

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值