阿里禁用select *,spring推荐使用构造器注入---why?

select *

阿里开发手册中规定:【强制】在表查询中,一律不要使用 * 作为查询的字段列表,需要哪些字段必须明确写明。

原因

  • 无用的列会增加数据传输的时间和网络的开销
  • 对于不需要的大字段会增加额外的io操作
    解释:在MySQL、InnoDB中当大字段的存储量超过728个字节的时候,数据库会将超出部分序列化到别的地方。当查询的时候进行io读取
  • 不会被MySQL优化器的“覆盖索引”策略优化(业内极推荐的查询优化方式)

spring构造注入

在开发中@Autowired或者@Resource使用起来及其方便、简单。
但是每次使用是都有个小问题
阿里禁用select *,spring推荐使用构造器注入---why?
直译为:不建议现场注入

原因

官方文档给的解释:
The Spring team generally advocates constructor injection as it enables one to implement application components as immutable objects and to ensure that required dependencies are not null. Furthermore constructor-injected components are always returned to client (calling) code in a fully initialized state.
翻译:
Spring团队通常提倡构造函数注入,因为它使人们能够将应用程序组件实现为不可变对象,并确保所需的依赖项不为null。此外,构造函数注入的组件总是以完全初始化的状态返回给客户机(调用)代码。
原因很明显了

  • 依赖不可变
  • 依赖不为空
    当要实例化FooController的时候,由于自己实现了有参数的构造函数,所以不会调用默认构造函数,那么就需要Spring容器传入所需要的参数
    依赖不为空(省去了我们对其检查):当要实例化FooController的时候,由于自己实现了有参数的构造函数,所以不会调用默认构造函数,那么就需要Spring容器传入所需要的参数,spring不会允许空值传入,空值就会报错。而set注入是允许赋值为null的
  • 完全初始化的状态
    向构造器传参之前,要确保注入的内容不为空,会调用依赖组件的构造方法完成实例化。在Java类加载实例化的过程中,构造方法是最后一步(之前如果有父类先初始化父类,然后自己的成员变量,最后才是构造方法),所以返回来的都是初始化之后的状态。

结束语

对个人碰见的疑惑进行归纳解答。-----做记录

上一篇:什么是软件的性能测试?带你了解性能测试!!!(建议收藏)


下一篇:《iOS和tvOS 2D游戏开发教程》——第1章,第1.3节挑战