}
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包名获取方式
-
第一种通过定义一个辅助服务 AccessibilityService 中 AccessibilityEvent 的getPackageName 获取
-
第二种通过 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 权限
/**
-
Have the system perform a force stop of everything associated with
-
the given application package. All processes that share its uid
-
will be killed, all services it has running stopped, all activities
-
removed, etc. In addition, a {@link Intent#ACTION_PACKAGE_RESTARTED}
-
broadcast will be sent, so that any of its registered alarms can
-
be stopped, notifications removed, etc.
-
You must hold the permission
-
{@link android.Manifest.permission#FORCE_STOP_PACKAGES} to be able to
-
call this method.
-
@param packageName The name of the package to be stopped.
-
@param userId The user for which the running package is to be stopped.
-
@hide This is not available to third party applications due to
-
it allowing them to break other applications by stopping their
-
services, removing their alarms, etc.
*/
public void forceStopPackageAsUser(String packageName, int userId) {
try {
getService().forceStopPackage(packageName, userId);
} catch (RemoteException e) {
throw e.rethrowFromSystemServer();
}
}
/**
-
@see #forceStopPackageAsUser(String, int)
-
@hide
*/
@SystemApi
@RequiresPermission(Manifest.permission.FORCE_STOP_PACKAGES)
public void forceStopPackage(String packageName) {
forceStopPackageAsUser(packageName, mContext.getUserId());
}
当我们执行反射调用的时候,系统会提示错误,App需要是platform系统平台签名,AndroidManifest添加 android:sharedUserId=“android.uid.system” 才可以使用forceStopPackage方法
<permission android:name=“android.permission.FORCE_STOP_PACKAGES”
android:permissionGroup=“android.permission-group.SYSTEM_TOOLS”
android:protectionLevel=“signature”
android:label=“@string/permlab_forceStopPackages”
android:description=“@string/permdesc_forceStopPackages”/>
- 反射调用
ActivityManager am= (ActivityManager) mContext.getSystemService(Context.ACTIVITY_SERVICE);
Method method = Class.forName(“android.app.ActivityManager”).getMethod(“forceStopPackage”, String.class);
method.invoke(am, packageName);
最后
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。
因此我收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
6957)]
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!