笔记52 | 优化一段苏基平大神的代码记录

地址

http://blog.csdn.net/xiangyong_1521/article/details/78814608


目录

  • 苏大神的原代码
  • 现代码

苏大神的原代码

private void leaveCarApp(List<String> packageNames){  //把需要保留的APP包名传进来
            for (int i = 0; i < carPackage.length; i++) {  //遍历所有需要匹配的APP名称
            int count = 0; 
            for(int j = 0;j<packageNames.size();j++){ //遍历所有需要保留的APP名称
                String packageName = packageNames.get(j);
                if(packageName.equals("")){ //没有要保留的APP
                    removeAppsFromName(apps,carPackage[i]); //从第一个开始隐藏
                }else{
                    int size =
                    Log.i("md", "j: "+j);
                    if (!carPackage[i].equals(packageName)) {//判断遍历的包名是否匹配
                        count +=1;                  

                        if(count == packageNames.size()){//如果是第一次循环遍历到匹配就跳出不处理
                            removeAppsFromName(apps,carPackage[i]); //就去除不需要保留的包名APP

                        }
                    }else{
                        j = packageNames.size();//跳出J的遍历
                    }
                }
              }
           }
         }

此段代码的作用是处理一些是否要显示的APP,将需要显示的程序package传到leaveCarApp()方法中,通过与String[] carPackage中的程序名字匹配来实现是否显示,每一段我都有做注释,特别绕,每次都绕不进去~~~;


现代码

绕了半天感觉摸出点头绪之后,立马优化!

private void leaveCarApp(List<String> packageNames){ //Evan add it for 20171215
         for (int i = 0; i < carPackage.length; i++) {
             if (packageNames.equals("")) {
                 removeAppsFromName(apps,carPackage[i]);
             }else{
                 if (!packageNames.contains(carPackage[i])) //carPackage[i]是否包含于需要显示的APP包名组
                     removeAppsFromName(apps,carPackage[i]); 
             }
         }
     }

是的,之前觉得这上段苏大神的代码真尼玛高深莫测遥不可及,现在自己简化了后觉得,原来一个contains方法就实现了弯道超车~~~

这是一种很好的feel


原文发布于微信公众号 - 项勇(xiangy_life)

原文发表时间:2017-12-15

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏黑白安全

黑客通过远程桌面服务安装新型 Matrix 勒索软件变体

MalwareHunterTeam 本周发现了两个新的 Matrix Ransomware 变体,这些变体正在通过被黑客入侵的远程桌面服务进行安装。尽管这两种变...

983
来自专栏黑白安全

黑客组织“隐匿者”技术升级再次暴力威胁入侵全网用户

区块链安全咨询公司 曲速未来 表示:"隐匿者"最早出现在2014年,此后一直从事入侵服务器或者个人主机的黑色产业,他们通过植入后门程序控制这些设备(肉鸡),然后...

2176
来自专栏FreeBuf

详细分析使用Certutil解码的Office恶意软件

最近发现使用certutil进行解码的office恶意软件,这种恶意软件通过OLE机制落地通过BASE64编码的恶意软件,然后通过调用certutil来进行解码...

2684
来自专栏進无尽的文章

支付-支付宝

  (需要实名认证这个支付宝账号,需要提供企业资料,成为企业支付宝账号,一般为公司的支付宝账号)

3341
来自专栏张善友的专栏

使用反向代理发布内网服务

DMZ是英文“demilitarizedzone”的缩写,中文名称为“隔离区”,也称“非军事化区”。它是为了解决安装防火墙后外部网络不能访问内部网络服务器的问题...

2178
来自专栏FreeBuf

绿盟科技威胁分析报告:那些年,那些 Apache Struts2 的漏洞

每次 Apache Struts2 漏洞爆发都在互联网上掀起腥风血雨,我们整理了近年来 Apache Struts2 高风险漏洞的信息供大家参考。针对此次 Ap...

23610
来自专栏FreeBuf

Malwaresearch:在Openmalware.org上查找恶意软件的命令行工具

Malwaresearch是一个在Openmalware.org上查找恶意软件的命令行工具,旨在加快查找及下载恶意软件样本的过程。 该工具旨在通过命令行界面加快...

2269
来自专栏ml

Linux下如何查看自己的服务器有没有无线网卡

还是实验室那台破服务器,连不上网。有没有界面,所以想着如何用一些命令来链接上 热点。 当然,在linux下链接wifi没有win下那么一点就好了! ...

4505
来自专栏ytkah

微信公众号后台编辑器出现短暂故障 附找回素材的方法

  今天下午(大致为8月15日13:30-14:40),微信公众平台后台编辑器出现短暂故障,保存素材后会出现被清空的现象,15:30左右已全面修复。   对于因...

3576
来自专栏FreeBuf

黑吃黑:鬼影DDoS黑客追踪

0x00 概述 安天追影小组通过威胁态势感知系统发现了一个DDoS攻击控制事件。从一个控制事件开始进行了一次黑客追踪之旅。经过关联分析找到控制C2的样本,该样...

5608

扫码关注云+社区