`

Java开发中常见的危险信号

阅读更多

        这里将要谈及的很多“危险信号”通常都会收到来自于FindBugs等代码分析工具所发出的警告信息,流行的Java IDE也会将它们标记出来。不过,我发现有不少开发者(包括我自己)会忽略掉这些来自于工具与IDE的警告信息,要么是因为他们关掉了提示信息,要么是出于自身的开发习惯或是不理解与这些警告信息所关联的风险,因此会忽略掉警告信息。
  对引用使用==(而不是.equals)
  很多Java开发者都知道使用==比较原生类型数据,使用.equals比较引用类型数据。这是一条很容易记住的简单原则,Java开发者这么用也没什么问题。有时使用==来比较标准的Java类型引用(String、Integer、Long等等)也没问题,不过这要取决于被缓存的值的大小,因此这么做并不是一个好的做法。有时,我们需要检查标识的相等性而不是内容的相等性,在这种情况下使用==来比较引用就很适合了。相对而言,我更喜欢Groovy的处理方式,==类似于.equals,而===则是更加严格地比较标识。同理,使用!=来比较两个引用也是一个“危险信号”,因为如果待比较的两个对象不共享相同的标识(内存地址),即便他们拥有相同的内容也总是会返回true。
  对枚举使用.equals(而不是==)
  坦率地说,对于枚举,Java开发者使用==还是.equals都没有太大关系。不过,我更倾向于对枚举使用==。这么做最重要的原因就是对枚举使用==可以防止不小心将枚举与不相关的对象进行比较(永远不会相等)。Object.equals(Object)方法可以接收任意对象,这意味着编译器并不会强制限定传进来的对象要与被比较的对象是相同的类型。一般来说,我更喜欢静态的编译期问题检测而非动态运行期的问题检测,对枚举使用==可以满足这个要求。同理,在比较枚举时,!=与!.equals也是一样的。
  魔数与字符串字面值
  我经常会在Java代码中看到有人使用“魔数”和字符串字面值。他们对于未来的维护来说是一种“危险信号”,让我十分怀疑应用的正确性。在单个位置处将其标识为常量(如果可能用枚举来表示更佳),这么做可以改善未来的维护,并且让我可以更加自信地相信使用这些值的所有代码都在使用着相同的值。除此之外,在一个地方定义好常量与枚举可以更方便地使用IDE的“查找使用”特性来找到所有使用这些常量的地方。
  字符串常量
  在看到有限的相关字符串常量时,我就在想使用枚举应该更加适合。对于高度内聚的字符串常量的情况来说更是如此,因为枚举可以更好地表达出这些字符串所表示的概念。相比于字符串常量来说,枚举提供了编译期的静态类型安全与潜在的性能优势。对于程序的正确性来说,编译期的安全是最吸引我的地方。
  使用Java的“goto”
  很少有人会使用标签代码,如果使用了那也说明用法不当。换句话说,如果使用了也是滥用而已。在大多数情况下,使用Java的“goto”会造成代码的可读性极差。
  根据作用域来确定恰当的变量引用
  我认为这种方式永远都是不恰当的,但它却能运行,甚至有时是被某些Java开发者有意而为之。比如说,Java开发者将传递进方法的变量在方法执行时指向了另一个引用。该变量(临时指向方法参数)指向了另一个引用,直到方法结束为止,这时它脱离了作用域。在这种情况下,在方法签名的参数定义前加上final关键字会导致编译器错误,这也是我喜欢在方法参数前加上final的原因之一。对于我来说,在方法中声明一个新的局部变量是更加清晰且可读的方式,因为它只能在方法中使用。更为重要的是,作为代码的读者,我不知道是开发者有意希望该参数名只是指向一个不同的值还是引入了Bug,因为将参数重新指向新的引用实际上会改变调用端的值。如果我看到有人这么写,那么我就会找代码的编写者或是通过单元测试来验证代码的意图。
  equals(Object)与hashCode()方法的不匹配
  虽然我认为每个Java类都应该重写toString()方法,但对于equals(Object)与hashCode()方法来说却并不这么认为。我觉得只有在需要这些方法的场合下才应该重写类中的这两个方法,因为他们的存在暗示着其设计与开发某种程度上的完全改变。特别地,equals与hashCode方法要能满足其意图与契约(位于Object类的API文档),并且需要保持一致。大多数IDE与分析工具都会在其中一个方法重写而另一个没有重写的情况下给出提示。然而,我要确保equals与hashCode使用的是相同的属性,并且在这两个方法中属性的顺序要保持一致。

 

文章来源:http://vipshichg.iteye.com/blog/1993501

分享到:
评论

相关推荐

    Java开发实战1200例(第1卷).(清华出版.李钟尉.陈丹丹).part3

     《Java开发实战1200例》分为I、II两卷共计1200个例子,包括了开发中各个方面最常用的实例,是目前市场上实例最全面的开发类图书;书中实例来源于多位工程师的多年积累,具有很强的实用性。 本书是第II卷,以开发...

    2021-2022计算机二级等级考试试题及答案No.11753.docx

    **知识点11:** 话筒是一种常见的输入设备,用于捕捉声音信号并将之转换为电信号。在计算机系统中,话筒主要用于语音识别、视频会议等应用场景。 以上是对给定文件中提及的知识点进行的详细解释。通过这些知识点的...

    计算机远程综合监控系统在煤矿中的应用

    JSP(JavaServer Pages)、Struts框架以及JDBC(Java Database Connectivity)等技术是常见的开发组件。 5. 应用GIS技术。地理信息系统(Geographic Information System, GIS)技术在远程综合监控系统中用于空间...

    无人小车速度控制系统的设计与实现_速度控制系统论文毕业设计范文.pdf

    而JDK则可能指的是Java Development Kit,虽然在嵌入式系统中Java应用相对较少,但这里可能是用于辅助或配合STM32进行程序开发的工具。 此外,传感器技术在无人小车中起着至关重要的作用。它们可以收集环境信息,如...

    洗浴场水温控制系统毕业设计.zip

    常见的温度传感器有热电偶、热电阻和半导体温度传感器等,它们将温度转换为电信号,供控制器处理。 3. 嵌入式系统:系统中的控制器可能是基于单片机或微控制器的嵌入式设备,如Arduino或Raspberry Pi。这些设备具有...

    安卓Android源码——获取Gps信息的程序源码.zip

    在安卓(Android)平台上开发应用程序时,获取GPS(全球定位系统)信息是一项常见的任务,它允许用户定位、导航或者获取位置相关的服务。本压缩包"安卓Android源码——获取Gps信息的程序源码.zip"提供了实现这一功能...

    火灾报警器源码.zip

    开发者可能使用了一些常见的编程语言,如C++、Python或Java,来实现这些功能。源码结构可能包含多个文件夹,每个对应一个功能模块,便于代码管理和维护。 在分析和学习这个源码时,开发者需要具备基本的编程知识,...

    android_wifi_sample:这是一个用于查询wifi强度和数据强度并更新UI的android示例应用程序

    在Android平台上,开发一款应用程序来查询Wi-Fi强度和数据连接强度是常见的需求,尤其是在网络通信相关的应用中。这个“android_wifi_sample”项目就是一个很好的实践案例,它展示了如何在Android环境中实时获取Wi-...

    电子政务-带报警功能的施工升降机控制电路.zip

    一旦检测到异常,报警系统会立即启动,通过声光信号提醒操作员和现场工作人员,同时可能还会触发自动停车机制,防止进一步的危险。 在电子政务的范畴内,这种技术应用可能涉及数据采集、传输和处理。数据可能通过...

    En-Emergencias-Android:在紧急情况下用作工具的应用程序

    首先,我们要理解Java在移动开发中的重要性。Java是一种广泛应用于移动平台的编程语言,具有跨平台的特性,使得开发的软件能够在多种设备上运行,包括Android系统。"En-Emergencias-Android"利用Java的稳定性和灵活...

    Linux 和Unix 安全编程HOWTO.pdf

    - **C/C++ 中的危险**:介绍了 C/C++ 中容易导致缓存溢出的函数。 - **C/C++ 中库的解决方案**:提供了一些常用的库函数,如 `strlcpy` 和 `strlcat`,以帮助防止缓存溢出。 - **C/C++ 的编译解决方案**:介绍了一些...

    PSTL-Controle-de-traffic-ferroviaire

    例如,CTC(集中联锁)或CBTC(基于通信的列车控制)是两种常见的铁路信号协议。控制器需要理解和执行这些协议,以生成正确的控制指令。 4. **Java编程语言**:标签"Java"表明项目是使用Java语言编写的。Java是一种...

    大厂的Android面试题.pdf

    - 常见的图片加载框架如Glide或Picasso,在加载过程中会利用缓存减少网络请求次数,提高加载速度和用户体验。 3. **模块化实现** - 模块化可以帮助团队更好地管理大型项目,提高代码可维护性和重用性。 - 实现...

    自动化

    在现代社会,自动化已经渗透到各个行业中,从制造业到服务业,再到软件开发和数据分析,无处不在。 自动化的核心在于利用软件、硬件设备以及算法来执行原本需要人工完成的任务。这不仅可以降低人力成本,还可以提升...

    Hanghe, a marine navigator-开源

    其开发语言采用的是Java 1.6,这使得航合具有跨平台的优势,可以在多种操作系统上运行,如Windows、Linux和Mac OS。 在"航合"中,BSB和KAP图表是关键组成部分。BSB格式是美国海军制定的一种用于存储和分发数字航海...

Global site tag (gtag.js) - Google Analytics