笔记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 条评论
登录 后参与评论

相关文章

来自专栏即时通讯技术

手把手教你读取Android版微信和手Q的聊天记录(仅作技术研究学习)

特别说明:本文内容仅用于即时通讯技术研究和学习之用,请勿用于非法用途。如本文内容有不妥之处,请联系JackJiang进行处理!

942
来自专栏FreeBuf

路由器漏洞分析第五弹:CVE-2018-5767远程代码执行

*本文作者:kczwa1,本文属 FreeBuf 原创奖励计划,未经许可禁止转载。

1092

Apache Hadoop:通过重构降低技术债务

如果没有将实际行动纳入代码来控制和解决技术债务的话,那么技术债务将一文不值。为了阐述这种能自动修正代码缺陷的能力,而这些缺陷恰恰又是增加这些意外债务的元凶,我们...

972
来自专栏醒者呆

【精解】开发一个智能合约

智能合约 这两天被老大搞去搬砖,学习计划有变但无大碍,这篇文章将仔细分析智能合约相关内容。 关键字:智能合约,remix,Solidity,truffl...

97410
来自专栏优启梦

渗透测试中的域名伪装原理

今天在《网络渗透测试--保护网络安全的技术、工具、过程》一书中看到了一个关于对恶意链接进行域名伪装的方法,以前从不知道的一个方法,特此记录下来:

1535
来自专栏Crossin的编程教室

【我问Crossin】Python 能被运用在哪些领域?

1 if __name__ = "__main__" 是什么意思? if __name__ = "__main__" 用来判断当前文件是否被直接执行。 一个 p...

2406
来自专栏FreeBuf

逆向工厂(一):从hello world开始

* 本文原创作者:追影人,本文属FreeBuf原创奖励计划,未经许可禁止转载 前言 从本篇起,逆向工厂带大家从程序起源讲起,领略计算机程序逆向技术,了解程序的运...

2288
来自专栏HansBug's Lab

一个很逗的东西——Jd

这个嘛是本人专门为了NOI上面对拍程序写的对拍程序,已经经历了NOI2015的考验;更重要的是——纯Pascal的哦(HansBug:其实是我不会写.sh脚本T...

28712
来自专栏java学习

Java每日一练(2017/6/1)

Java基础 | 数据库 | Android | 学习视频 | 学习资料下载 课前导读 ●回复"每日一练"获取以前的题目! ●答案公布时间:为每期发布题目的第二...

2507
来自专栏Aloys的开发之路

Cache模拟器(CacheSim)

最近写了一个Cache的模拟器,由于平时空余时间比较分散,前前后后用了一周多的时间,基本实现的Cache的模拟功能(通过读取trace文件得到相应的命中率),能...

1947

扫码关注云+社区