开源软件的坏味道

简介: # 前言 ![image.png](http://ata2-img.cn-hangzhou.img-pub.aliyun-inc.com/9f2ea42a91affcd3c6f4a82e62aea6d4.png) 开源软件的世界,我们一直带着一颗敬畏之心来使用与学习,我们总觉得他们高高在上、他们完美无缺。但金无足赤,强如JDK、Spring也同样有这样或那样的问题。 他们也并非那么遥不可及,

前言

image.png
开源软件的世界,我们一直带着一颗敬畏之心来使用与学习,我们总觉得他们高高在上、他们完美无缺。但金无足赤,强如JDK、Spring也同样有这样或那样的问题。
他们也并非那么遥不可及,我们也未必只配仰望,这里我们列举开源软件的那些“bad smell”,前车之鉴、后车之覆,开源软件也同样不完美。站在巨人肩膀上看到巨人的不完美,激励着我们往更成功的巨人之路迈进 ?

JDK篇

Handler#setFormatter

代码片段出自java.util.logging.Handler#setFormatter,作者为了不让空指针异常下传,提前做一次检查,这本无可厚非,但采用这种方式来检查,或许并不是个优雅的方案。

"Comments Do Not Make Up for Bad Code"
--- Robert C.Martin 《Clean Code》

image.png

同样在java.util包下,java.util.Objects#requireNonNull在此处应该是更好的选择。

public static <T> T requireNonNull(T obj, Supplier<String> messageSupplier) {
    if (obj == null)
        throw new NullPointerException(messageSupplier.get());
    return obj;
}

Spring篇

BeanUtils#copyProperties

代码出自org.springframework.beans.BeanUtils#copyProperties,代码中引入了过多的if,嵌套的层级达到6层之多。但细看不难发现,其实都不是不同的逻辑分支,而是一些filter过滤,一方面用lambda的filter可以优化,提前return也是个不错的选择。

"Deeply nested code hurts readability and is error-prone"

--- Google Code Health Series

image.png

后续

“挑刺”不是目的,有则改之无则加勉,他人之优与劣、功与过皆能在成功路上,助我等一臂之力。
PS.本文会长期跟进,大家有发现一些开源软件的坏味道,也可以直接在评论区留言,或发至我的邮箱 xiaolong.nxl@alibaba-inc.com,我会整理好后更新进去。

目录
相关文章
|
2月前
信不信?工作这么多年,还有很多网工不知道光模块光衰的正常范围?
信不信?工作这么多年,还有很多网工不知道光模块光衰的正常范围?
165 2
|
2月前
|
SQL 安全 数据安全/隐私保护
【惊心动魄!】Rails开发者的噩梦:那些差点毁了我职业生涯的安全漏洞……
【8月更文挑战第31天】本文探讨了加强Ruby on Rails应用安全性的最佳实践,包括防止SQL注入、XSS与CSRF攻击及安全存储密码等。通过对比不安全与安全的代码示例,如使用`User.find`替代`find_by_sql`避免SQL注入,利用`h`方法防御XSS攻击,以及借助`bcrypt`库加密密码,本文提供了实用的指导。同时强调了定期更新Rails框架和使用`brakeman`等工具的重要性,以持续保障应用安全。
23 0
|
5月前
5款简单好用的软件,总有一款适合你
今天为大家推荐五款不常见但好用的win10软件,它们都有着各自的特色和优势,相信你会喜欢的。
110 0
推荐5款超级好用的软件,总有一款适合你
今天我要向大家推荐5款超级好用的效率软件,无论是在生活还是办公中都能够极大地提高效率。这些软件可以帮助你解决许多问题,而且每个都是真正的神器。
75 0
|
安全 数据安全/隐私保护 计算机视觉
分享5款用起来很好用的软件,总有一款适合你
很多软件用起来很好用,但是由于这样那样的原因,一直没什么知名度,但是不代表它们不好用,我的任务就是把这些宝藏分享给大家。
131 0
|
监控
分享5款十分小众的软件,不好用你找我
今天推荐5款十分小众的软件,但是每个都是非常非常好用的,用完后觉得不好用你找我。
92 0
|
设计模式 Oracle IDE
讲码德!避免这些代码坏味道,努力做一名优秀的程序员
讲码德!避免这些代码坏味道,努力做一名优秀的程序员
|
安全 数据建模 UED
思考:互联网创业三思后行还是想到就做?
思考:互联网创业三思后行还是想到就做?
162 0
思考:互联网创业三思后行还是想到就做?
|
物联网 大数据 数据库
产品:“嘘,这事千万别让开发知道”
作为2019年首场最受瞩目的云计算开发者大会,阿里云火力全开。本次开发者大会聚焦开源大数据、IT基础设施云化、数据库、云原生、物联网五大主力方向。
2187 0
|
程序员 SQL Java
程序员最头疼的七件事
懂点技术,瞎指挥 有人说不懂技术的瞎指挥很可怕,我倒是觉得懂点技术,然后指手画脚更可怕! 有个国企的项目,甲方负责人李总是个局里的二把手,不知道什么时候了解了一点编程的技术, 每次开需求会都是和我们大谈如何开发软件,他的口头禅就是: 这个需求,用个SQL从数据库一选不就出来了?!你们怎么得开发一周?!别想蒙我! 唉,他怎么能考虑到用SQL的like是效率极低的, 数据量大了是要崩溃的,我们得建立全文索引,需要用一套基于搜索的解决方案才行。
1009 0