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

java 绑定微信号开发

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

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

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

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

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

使用StringBuffer而不是StringBuilder

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

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

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

过多的显式投射

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

接口或类的使用范围太广

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

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

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

使用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代码中的红色标志的文章一样,本文中讨论的“红色标志”通常是指在适当和特定的情况下使用时不一定正确的事物,但通常确实表明事物不那么正确因为它们可能会在更大的应用程序中使用。


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

java 绑定微信号开发

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java SpringMVC ,Controller 是处理用户请求的一个核心组件。Controller 的主要作用是将用户的请求映射到相应的处理方法,并返回处理结果给用户。 下面是一些关于 SpringMVC Controller 的详解: 1. Controller 的作用 Controller 主要用于处理用户请求,并将请求转发到相应的业务逻辑层进行处理。Controller 的核心作用是将用户请求映射到相应的处理方法,并将处理结果返回给用户。 2. Controller 的实现方式 在 SpringMVC ,Controller 的实现方式有多种,最常见的是通过 @Controller 注解或 @RestController 注解来实现。使用 @Controller 注解的类需要在方法上添加 @RequestMapping 注解来指定请求的 URL 地址。而使用 @RestController 注解的类则可以直接在方法上添加 @RequestMapping 注解,同时还可以使用 @GetMapping、@PostMapping、@PutMapping 和 @DeleteMapping 注解来指定 HTTP 请求方法。 3. Controller 的参数绑定 在处理用户请求时,Controller 还需要将请求的参数绑定到相应的处理方法。参数绑定的方式有多种,最常见的是通过 @RequestParam 注解、@PathVariable 注解以及 @RequestBody 注解来实现。 其,@RequestParam 注解用于绑定请求参数,@PathVariable 注解用于绑定 URL 的参数,@RequestBody 注解用于绑定请求体的参数。 4. Controller 的返回值 在处理用户请求后,Controller 还需要将处理结果返回给用户。Controller 的返回值有多种,最常见的是返回一个 ModelAndView 对象或一个 JSON 格式的数据。 如果需要返回一个页面,可以使用 ModelAndView 对象,并通过 addObject 方法来添加数据模型。如果需要返回 JSON 格式的数据,则可以使用 @ResponseBody 注解来将处理结果转换为 JSON 格式的数据。 5. Controller 的异常处理 在处理用户请求时,Controller 还需要处理可能出现的异常情况。SpringMVC 提供了多种异常处理机制,最常见的是通过 @ExceptionHandler 注解来实现。可以在 Controller 添加一个 @ExceptionHandler 注解的方法来处理指定类型的异常,当出现异常时,就会自动调用该方法进行处理。 以上就是关于 SpringMVC Controller 的详解,希望可以对你有所帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值