java 绑定微信号开发

在《 Java开发中的常见危险信号》一文中,我研究了一些不一定本身就是错误或不正确的做法,但它们可能表明存在更大的问题。 这些“红色标记”类似于“代码气味”的概念,我在这篇文章中引用的某些特定“红色标记”被称为“代码气味”。 如我在第一篇文章中所述,这些“红色标志”中的几个被认为足够重要,以至于静态代码分析工具和Java IDE会对其进行标记。

直接“记录”消息到stdout或stderr

日志记录框架已经在Java中使用了很长时间了,今天,我们有各种各样的日志记录框架 (其中一些相互构建),包括传统的Log4j 1.2 , log4j 2 , java.util.logging ( Java Logging API ), Apache Commons Logging和SLF4J 。 鉴于此,当我在Java代码中看到System.out和System.err引用时,我感到很惊讶。

有许多原因直接引起人们关注是否存在直接写入标准输出或标准错误的Java代码。 引起关注的一个原因是,这可能意味着不成熟的代码,该代码原本打算在以后更改为日志记录,但却没有得到最终的关注。 引用标准输出和标准错误的另一个缺点是,“日志”消息可能不会出现在日志文件中,而其余日志则由日志框架编写。 第三个问题是,日志记录框架提供了许多不错的功能,而简单地写入标准输出和标准错误并没有提供这些功能。 这些功能包括轻松控制所记录消息的级别的能力,控制是否在指定的记录级别下是否降低性能以生成较大的输出字符串的能力,轻松将捕获的异常与已记录的错误消息相关联的功能,并能够轻松地将输出重定向到不同的目的地和不同的格式。 尽管所有这些都可以在直接处理输出和错误流时手动完成,但它需要自定义工作,而不是“开箱即用”。

除了使用System.outSystem.err直接访问外,Java代码中还存在一些写入标准输出和标准错误的表现形式(尽管它们通常隐式包含System.outSystem.err )。 例如, Throwable.printStackTrace() [在Exception的处理中更常用],正如其Javadoc所言,“将此throwable及其回溯打印到标准错误流中。”

使用StringBuffer而不是StringBuilder

这诚然是一个很小的事情,但它可以指示过时的 Java代码( StringBuffer的推出在JDK 1.0和StringBuilder的介绍在J2SE 5 )或Java代码在开发商没有明白之间的差别的StringBuffer和StringBuilder的 。 在大多数情况下,两者之间的性能差异对手头的应用程序并不重要,但是由于StringBuilder在大多数我已经看到使用StringBuffer的 情况下更可取 ,因此人们也可能会喜欢使用StringBuilder通常具有轻微的性能优势。 我有困难的时候,回顾一个实例中,我所看到StringBuffer使用其中StringBuilder不可能被替代。 一个相关的危险信号是将String串联与StringBuilder混合在其构造函数或重载的append方法中。

方法和构造函数中的参数过多

当方法或构造函数的参数过多时,尤其是在多个参数具有相同类型的情况下,我总是担心其客户端无法正确使用该方法或构造函数。 例如,如果某个方法接受三个String和三个boolean ,则客户端很容易混淆传入的特定值。在这种情况下,编译器无济于事,这是检测问题根源的唯一方法(甚至根本不存在问题)在运行时(通过单元测试或其他测试,或者可悲的是,在软件的常规执行过程中)。 对于不正确的设计,太多的参数也可能成为“危险信号”。 我不会在本文中更深入地讨论这个“红色标志”,因为我已经介绍了这个“红色标志”,多种解决方法,并在一系列八篇博客文章中介绍了它。

  • Java方法中的参数太多,第1部分:自定义类型
  • Java方法中的参数太多,第2部分:参数对象
  • Java方法中的参数太多,第3部分:构建器模式
  • Java方法中的参数太多,第4部分:重载
  • Java方法中的参数太多,第5部分:方法命名
  • Java方法中的参数太多,第6部分:方法返回
  • Java方法中的参数太多,第7部分:可变状态
  • Java方法中的参数太多,第8部分:工具

过多的显式投射

显式转换可能是危险信号情况的最佳示例之一,在该情况下,转换本身可能不会影响正常工作的任何功能或逻辑,但是提示情况不尽如人意。 强制转换可能意味着较差的设计选择(例如,未正确使用多态性,在不适当的情况下使用继承,或迫使从未设计过的东西放在一起)。 在许多情况下(例如,在获取Spring Framework上下文bean时),显式强制转换当然是适当的或必需的,但是显式强制转换也可以用作拐杖,以使未经过精心设计的工作正常进行。 强制转换还可以指示过于广泛的API或过于广泛的API中使用的接口(在下一项中突出显示)。

接口或类的使用范围太广

当Set或List或更具体的接口更合适时,我经常看到Collection接口用作方法参数或返回类型。 例如,一个返回Collection但希望客户端代码知道返回的Collection是有序的方法,应返回List或更具体的接口或List实现。 同样,如果某个方法需要一个有序的Set ,则它应该将该方法宣传为希望有SortedSet或类似的接口或实现类。 对于给定的合同,当返回或期望作为参数的接口或类太宽泛时,就会迫使某人“知道”这种情况,并强制转换为适当的级别以获取他们所依赖的功能。

使用适当的级别或接口或类不仅可以避免不必要的显式转换。 适当的类型级别比单纯的文档更好地宣传和执行方法合同。 但是,它远不止于此。 在某些情况下,当公告的接口太宽而无法捕获方法协定中的假设时,可能会发生重大的运行时异常。 例如,通用接口可能会选择支持一种方法,但是该接口的实际实现在被调用时会引发UnsupportedOperationException ,因为它没有实现该可选方法。 在UnsupportedOperationException和ClassCastException之间,使用过宽的接口或类可能会导致潜在的严重运行时问题。

这并不是说应该避免使用接口或广泛的类。 而是说,应该在返回类型和参数类型中使用适当的抽象度,以便适当地宣告和强制执行调用双方的预期行为。

使用List.addAll()

使用重载的List.addAll()方法之一会让我感到紧张,当我在代码中看到它时,它会变成一个鲜红色的标志。 这并不意味着使用它总是错误的,但是似乎由于使用不当而导致我看到了很多肿的内存问题。 因为List会添加开发人员喜欢的“重复”对象,所以错误的代码可以用冗余对象以指数方式填充这些List 。 此范围的负面影响从潜在的性能障碍到内存不足。 当我看到使用List.addAll() ,我会仔细检查代码并对其进行单元测试,以确保其内存消耗不会失控。 如前面的“红色标记”中所述,必须对Collection.addAll()任何使用进行类似于List.addAll()分析,直到可以肯定地知道Collection实际上不是List为止。

非Java方言

也许对我而言,最好的例子是“危险信号”,这是与“普遍接受的Java编码标准 ”相反或明显不同的惯用语和代码约定的频繁使用。 使用名称,大小写或其他样式问题都不会直接影响代码的正确性或性能。 但是,这些差异仍然是“危险信号”,警告逻辑或性能方面的潜在实际问题,因为使用这些明显的非标准习语和约定意味着开发人员可能是Java的新手,因此可能犯了一些新的错误。 Java。 关于“没有口音”编写Java代码的重要性的一篇很好的文章是讲没有口音的Java语言 。 在该文章中,作者Elliotte Rusty Harold撰写了有关如何更难以阅读和维护此类代码的文章。

在相对罕见的情况下,这可能会从样式问题变为影响问题。 当人们以一种在另一种语言(例如C或C ++)中最有意义的方式编写Java代码,但没有Java的替代方法那么有意义时,就会发生这种情况。

结论

就像我第一篇关于Java代码中的红色标志的文章一样,本文中讨论的“红色标志”通常是指在适当和特定的情况下使用时不一定正确的事物,但通常确实表明事物不那么正确因为它们可能会在更大的应用程序中使用。

参考:来自JCG合作伙伴 Dustin Marx的Inspired by Actual Events博客中的Java开发中的更多常见 危险信号 。

翻译自: https://www.javacodegeeks.com/2013/12/more-common-red-flags-in-java-development.html

java 绑定微信号开发

java 绑定微信号开发_Java开发中的更多常见危险信号相关推荐

  1. java 绑定微信号开发_Java开发中的常见危险信号

    java 绑定微信号开发 在开发,阅读,复审和维护成千上万行Java代码的几年中,我已经习惯于看到Java代码中的某些" 危险信号 ",这些信号通常(但可能并非总是)暗示着代码有问 ...

  2. 【源码+图片素材+详细教程】Java游戏开发_Java开发经典游戏飞翔的小鸟_飞扬的小鸟_Java游戏项目Flappy Bird像素鸟游戏_Java课程设计项目

    课程目标: 1.通过本课程的学习巩固Java的相关基础知识,例如循环判断,数组和集合的使用,对象的继承,接口的实现,窗口的创建,事件监听,图形绘制. 2.完成小鸟的移动,管道自动生成.碰撞死亡,计分系 ...

  3. Java开发中的常见危险信号

    在开发,阅读,复审和维护成千上万行Java代码的几年中,我已经习惯于看到Java代码中的某些" 危险信号 ",这些信号通常(但可能并非总是)暗示着代码问题. 我不是在谈论总是错误的 ...

  4. 个人微信号二次开发sdk协议,微信个人号开发API接口

    个人微信号二次开发sdk协议,微信个人号开发API接口 微信SDK程序概要说明 个人微信号开发sdk非微信ipad协议.非mac协议,非安卓协议,api可实现微信99%功能: 无需扫码登录.可收发朋友 ...

  5. 简书发布文章时要求绑定微信号后才能发布

    注册-写文章-发布提示[必须绑定微信号才可以发布文章],我可拜拜了您内,删文章,注销账号. 一个手机号不够你实名制的?隐私我不给你的你不能抢啊! sb

  6. java api 开发_Java开发人员应该知道的前20个库和API

    java api 开发 优秀且经验丰富的Java开发人员的特征之一是对API的广泛了解,包括JDK和第三方库. 我花了很多时间来学习API,尤其是在阅读了Effective Java 3rd Edit ...

  7. java使用场景什么意思_Java开发中类隐藏及应用场景分析是什么?

    隐藏是JAVA语言平台中提出来的一个新名词.其次在其他语言平台上,也有类似的说法,只是称呼不一样而已.但是隐藏的功能对于应用程序开发来说,特别是大型应用程序设计,非常的有用.作为一名合格的JAVA平台 ...

  8. 个人微信号二次开发的实现,api接口

    各位兄弟姐妹们大家好!!!! 我又瞧到了好玩的微信机器人分享给大家! 社群运营这几年风头正盛,不能落伍啊,我们也赶紧组建了社群. 但是微信群还是社交属性为主的,当我们运营多个社群的时候会发现效率过低, ...

  9. JAVA计时函数的库_JAVA开发常用类库UUID、Optional、ThreadLocal、TimerTask、Base64使用方法与实例详解...

    1.UUID类库 UUID 根据时间戳实现自动无重复字符串定义 // 获取UUID public static UUID randomUUID() // 根据字符串获取UUID public stat ...

最新文章

  1. 蛮力法在查找算法中的应用(JAVA)--顺序查找
  2. ddt python_python-ddt实践
  3. 用计算机演银河系,专家首次用计算机模拟类银河星系 分辨率极高
  4. 万网空间的数据库配置方法
  5. 国内首位!Node.js社区将阿里云工程师张秋怡吸纳为CTC成员
  6. EJB3.0框架实例----区分有状态bean和无状态bean
  7. 大王——有趣干货集合
  8. 【JS基础】异步和单线程
  9. 深度学习2.0-37.循环神经网络层
  10. Android获取WIFI 的ssid 方法适配Android9.0
  11. win7计算机无法最大化,win7系统窗口老是以最大化显示且不能还原的具体方法
  12. Centos7 kvm环境制作qcow2 格式镜像
  13. html怎么实现左右滚动,css实现左右滑动
  14. php气泡效果,ps绘制漂亮透明的泡泡效果
  15. C语言-进程——信号量
  16. 720_vr全景3D环物制作教程
  17. 0.91英寸OLED初始化程序
  18. GaRy-Liang的linux成长日记3-自动化安装
  19. CentOS 恢复 rm -rf * 误删数据--extundelete
  20. 联想v360安装linux双系统,V360在WIN7下安装XP双系统完美运行攻略.doc

热门文章

  1. codeforces 939C Convenient For Everybody 简直羞耻
  2. 使用org.apache.commons.io.FileUtils,IOUtils工具类操作文件
  3. vue watch监听对象
  4. Java 调用EXE
  5. C++描述杭电OJ 2016.数据的交换输出 ||
  6. ssm使用全注解实现增删改查案例——mybatis-config.xml
  7. java面向对象高级分层实例_BaseDao
  8. Android软键盘弹出时,覆盖布局,不是把布局顶上去的解决方法
  9. 什么注解可以改变BigDecimal类型的字段返回的小数位数?
  10. android 枚举类型比较大小写,Spring 3.0 MVC绑定枚举区分大小写