阿里规约认证(题库附答案)

认证分数

总结的考试题库

多选 1.如何处理单元测试产生的数据,下列哪些说法是正确的?ABC

A .测试数据入库时加特殊前缀标识。
B .测试数据使用独立的测试库。
C .自动回滚单元测试产生的脏数据。
D .无须区别,统一在业务代码中进行判断和识别。

解析
【推荐】和数据库相关的单元测试,可以设定自动回滚机制,不给数据库造成脏数据。或者对单元测试产生的数据有明确的前后缀标识。
正例:在 RDC 内部单元测试中,使用 RDC_UNIT_TEST_的前缀标识数据。
【强制】保持单元测试的独立性。

多选 2.关于并发处理,下列哪些说法符合《阿里巴巴Java开发手册》:ABC

A .线程资源必须通过线程池提供,不允许在应用中自行显式创建线程。
B .同步处理时,能锁部分代码区块的情况下不要锁整个方法;高并发时,同步调用应该考虑到性能损耗。
C .创建线程或线程池时,推荐给线程指定一个有意义的名称,方便出错时回溯。
D .推荐使用Executors.newFixedThreadPool(int x)生成指定大小的线程池。(线程池不允许使用 Executors 去创建,而是通过 ThreadPoolExecutor 的方式)

解析
正例:不允许在应用中自行显式创建线程,
Thread直接创建线程的弊端
(1)每次new Thread新建对象,性能差。
(2)线程缺乏统一管理,可能无限制的新建线程,相互竞争,有可能占用过多系统资源导致死机或OOM。
(3)缺少更多的功能,如更多执行、定期执行、线程中断。
线程池不允许使用 Executors 去创建,说明:Executors 返回的线程池对象的弊端如下:
1)FixedThreadPool 和 SingleThreadPool:
允许的请求队列长度为 Integer.MAX_VALUE,可能会堆积大量的请求,从而导致 OOM。
2)CachedThreadPool 和 ScheduledThreadPool:
允许的创建线程数量为 Integer.MAX_VALUE,可能会创建大量的线程,从而导致 OOM。

多选 3.下列哪些说法符合《阿里巴巴Java开发手册》:ACD

A .对于“明确停止使用的代码和配置”,如方法、变量、类、配置文件、动态配置属性等要坚决从程序中清理出去,避免造成过多垃圾。
B .永久弃用的代码段注释掉即可,即不用加任何注释。
C .对于暂时被注释掉,后续可能恢复使用的代码片断,在注释代码上方,统一规定使用三 个斜杠(///)来说明注释掉代码的理由。
D .不要在视图模板中加入任何复杂的逻辑。

解析
正例:永久弃用的代码建议删除。
【推荐】及时清理不再使用的代码段或配置信息。

说明:对于垃圾代码或过时配置,坚决清理干净,避免程序过度臃肿,代码冗余。
正例:对于暂时被注释掉,后续可能恢复使用的代码片断,在注释代码上方,统一规定使用三
个斜杠(///)来说明注释掉代码的理由。

多选 4.关于分页查询,下列哪些说法符合《阿里巴巴Java开发手册》:ABC

A .分页查询,当统计的count为0时,应该直接返回,不要再执行分页查询语句。
B .iBATIS自带的queryForList(String statementName,int start,int size)分页接口有性能隐患,不允许使用。
C .定义明确的sql查询语句,通过传入参数start和size来实现分页逻辑。
D .可使用存储过程写分页逻辑,提高效率。

解析
禁止使用存储过程,存储过程难以调试和扩展,更没有移植性。

多选 5.根据《阿里巴巴Java开发手册》,以下功能必须进行水平权限控制校验的有:ABCD

A .订单详情页面。
B .类目管理后台。
C .店铺装修后台。
D .订单付款页面。

解析
正例:隶属于用户个人的页面或者功能必须进行权限控制校验。

多选 6.关于数据库中NULL的描述,下列哪些说法符合《阿里巴巴Java开发手册》:BD

A .NULL=NULL的返回结果为true。
B .NULL与任何值的比较结果都为NULL。
C .NULL<>1的返回结果为true。
D .当某一列的值全是NULL时,sum(col)的返回结果为NULL。
解析:
知识点-mysql.
【强制】使用 ISNULL()来判断是否为 NULL 值。
说明:NULL 与任何值的直接比较都为 NULL。

正例:可以使用如下方式来避免 sum 的 NPE 问题:

SELECT IF(ISNULL(SUM(g)),0,SUM(g))
FROM table;

同样,条件中过滤NULL时,不能使用 column = NULL column != NULL应采取 IS NULL IS NOT NULL .

多选 7.关于接口使用抛异常还是返回错误码,下列哪些说法符合《阿里巴巴Java开发手册》:ABCD

A .向公司外部提供的http/api接口,推荐使用“错误码”方式返回异常或者错误信息。
B .对于应用内部的方法调用,推荐使用“抛出异常”的方式处理异常或者错误信息。
C .跨应用的RPC调用,推荐使用将“错误码”和“错误简短信息”封装成Result的方式进行返回。
D .对外提供的接口,一定要保证逻辑健壮性:尽量避免空指针等技术类异常;对于业务类异常要做好错误码或者异常信息的封装。

解析
对于公司外的 http/api 开放接口必须使用“错误码”;而应用内部推荐异常抛出;
跨应用间 RPC 调用优先考虑使用 Result 方式,封装 isSuccess()方法、“错误码”、“错误简
短信息”。
总结记忆口诀

公司外部错误码,
应用内部异常抛,
RPC调用Result去封装。

对外接口要健壮,
小心谨慎空指针,
业务异常应封装。

单选 8.关于类的序列化,下列说法哪些是正确的:D

A .类的序列化与serialVersionUID毫无关系。
B .如果完全不兼容升级,不需要修改serialVersionUID值。
C .POJO类的serialVersionUID不一致会编译出错。
D .POJO类的serialVersionUID不一致会抛出序列化运行时异常。

解析
序列化类新增属性时,请不要修改 serialVersionUID 字段,避免反序列失败
如果完全不兼容升级,避免反序列化混乱,那么请修改 serialVersionUID 值。
说明:注意 serialVersionUID 不一致会抛出序列化运行时异常

多选 9.关于Java的接口描述,下列哪些说法符合《阿里巴巴Java开发手册》:BCD

A .在接口类中的方法和属性使用public修饰符。
B .对于Service类,内部的实现类加Impl的后缀与接口区别。例如:ProductServiceImpl实现ProductService接口。
C .对于Service类,基于SOA的理念,是以接口方式暴露服务。
D .尽量不在接口里定义变量,如果一定要定义变量,肯定是与接口方法相关,而且是整个应用的基础常量。

解析
接口类中的方法和属性不要加任何修饰符号(public 也不要加),保持代码的简洁性,并加上有效的 Javadoc 注释。
尽量不要在接口里定义变量,如果一定要定义变量,肯定是与接口方法相关,并且是整个应用的基础常量。
例如:

 接口方法签名 void commit();
 接口基础常量 String COMPANY = "alibaba";

单选 10.集合在遍历过程中,有时需要对符合一定条件的元素进行删除,下列哪些说法是正确的:B

A .在 foreach 循环里进行元素的 remove操作。
B .使用Iterator方式,如果有并发,需要对Iterator对象加锁。
C .Iterator进行元素的删除操作,绝对是线程安全的。
D .Java无法实现在遍历时,进行删除元素操作。

解析
正例:不要在 foreach 循环里进行元素的 remove/add 操作。
remove 元素请使用 Iterator
方式,如果并发操作,需要对 Iterator 对象加锁。

多选 11.关于基本数据类型与包装数据类型的使用标准,下列哪些说法符合《阿里巴巴Java开发手册》:ABD

A .所有的POJO类属性必须使用包装数据类型。
B .RPC方法的返回值和参数必须使用包装数据类型。
C .因为JAVA的自动装箱与拆箱机制,不需要根据场景来区分数据类型。
D .所有的局部变量推荐使用基本数据类型。

解析
关于基本数据类型与包装数据类型的使用标准如下:

1) 【强制】所有的 POJO 类属性必须使用包装数据类型。
2) 【强制】RPC 方法的返回值和参数必须使用包装数据类型。
3) 【推荐】所有的局部变量使用基本数据类型。

说明:POJO 类属性没有初值是提醒使用者在需要使用时,必须自己显式地进行赋值,任何
NPE 问题,或者入库检查,都由使用者来保证。

多选 12.关于索引的设计,下列哪些说法符合《阿里巴巴Java开发手册》:ACD

A .对varchar类型的字段建立索引,必须指定索引长度。
B .对varchar类型的字段建立索引,不需要指定索引长度,这样索引区分度最好。
C .业务上具有唯一特性的字段(含组合字段),必须指定唯一索引。
D .建复合索引时,一般选择区分度高的字段放在最左列。

解析业务上具有唯一特性的字段,即使是多个字段的组合,也必须建成唯一索引。
在 varchar 字段上建立索引时,必须指定索引长度,没必要对全字段建立索引,根据
实际文本区分度决定索引长度即可。
建组合索引的时候,区分度最高的在最左边。
正例:如果 where a=? and b=? ,如果 a 列的几乎接近于唯一值,那么只需要单建 idx_a
索引即可。

多选 13.关于二方库版本号的命名方式,下列哪些说法符合《阿里巴巴Java开发手册》:ABCD

A .版本号命名格式:主版本号.次版本号.修订号。
B .主版本号:产品方向改变,或者大规模API不兼容,或者架构不兼容升级。
C .次版本号:保持相对兼容性,增加主要功能特性,影响范围极小的API不兼容修改。
D .修订号:保持完全兼容性,修复BUG、新增次要功能特性等。

多选 14.关于索引的使用,下列哪些说法是正确的:BCD

A .查询语句 WHERE a+1 = 5 可以利用a索引。
B .查询语句WHERE date_format(gmt_create, '%Y-%m-%d') = '2016-11-11'无法利用gmt_create索引。
C .当 c 列类型为 char 时,查询语句 WHERE c = 5 无法利用c索引。
D .索引字段使用时不能进行函数运算。

解析
索引字段使用时不能进行函数运算。

多选 15.关于生产环境的日志文件,下列哪些说法符合《阿里巴巴Java开发手册》:ABCD

A .异常信息应该包括两类信息:案发现场信息和异常堆栈信息。
B .日志文件推荐至少保存15天,因为有些异常具备以“周”为频次发生的特点。
C .避免重复打印日志,浪费磁盘空间,务必在log4j.xml中设置additivity=false。
D .错误日志和业务日志尽量分开存放。

解析
日志文件至少保存 15 天,因为有些异常具备以“周”为频次发生的特点。
【强制】避免重复打印日志,浪费磁盘空间,务必在 log4j.xml 中设置 additivity=false。
正例:
异常信息应该包括两类信息:案发现场信息和异常堆栈信息。如果不处理,那么通过
关键字 throws 往上抛出。

多选 16.关于代码注释,下列哪些说法符合《阿里巴巴Java开发手册》:ABD

A .特殊注释标记,请注明标记人与标记时间。
B .待办事宜(TODO):( [标记人,标记时间,[预计处理时间])
C .在注释中用FIXME标记某代码虽然实现了功能,但是实现的方法有待商榷,希望将来能改进
D .在注释中用FIXME标记某代码是错误的,而且不能工作,需要及时纠正的情况

解析
特殊注释标记,请注明标记人与标记时间。
1) 待办事宜(TODO):( 标记人,标记时间,[预计处理时间])。
2) 错误,不能工作(FIXME):(标记人,标记时间,[预计处理时间])。

多选 17.关于MySQL性能优化的描述,下列哪些说法是正确的:ABCD

A .主键查询优先于二级索引查询。
B .表连接有一定的代价,故表连接数量越少越好。
C .一般情况下,二级索引扫描优先于全表扫描。
D .可以使用通过索引避免排序代价。

解析
聚集索引:
每个存储引擎为InnoDB的表都有一个特殊的索引,叫聚集索引。聚集索引并不是一种单独的索引类型,而是一种数据存储方式。InnoDB表中聚集索引的索引列就是主键,所以聚集索引也叫主键索引

二级索引:
对于InnoDB表,在非主键列的其他列上建的索引就是二级索引(因为聚集索引只有一个)。二级索引可以有0个,1个或者多个。

索引查询优先级:主键索引>二级索引>全表
参考:https://www.cnblogs.com/yuanrw/p/10225659.html

多选 18.关于索引的设计和使用,下列哪些说法是正确的:ABCD

A .若查询条件中不包含索引的最左列,则无法使用索引。
B .对于范围查询,只能利用索引的最左列。
C .对于order by A或group by A语句,在A上建立索引,可以避免排序。
D .对于多列排序,需要所有所有列排序方向一致,才能利用索引。

解析
索引文件具有 B-Tree 的最左前缀匹配特性,如果左边的值未确定,那么无法使用此索引。

多选 19.关于类命名,下列哪些说法符合《阿里巴巴Java开发手册》:ABCD

A .抽象类命名使用Abstract或Base开头。
B .异常类命名使用Exception结尾。
C .测试类命名以它要测试的类的名称开始,以Test结尾。
D .如果使用到了设计模式,建议在类名中体现出具体模式。例如代理模式的类命名:LoginProxy;观察者模式命名:ResourceObserver。

多选 20.关于数据库模糊检索的描述,下列哪些说法符合《阿里巴巴Java开发手册》:ABD

A .绝对禁止左模糊。
B .绝对禁止全模糊。
C .绝对禁止右模糊。
D .全模糊或左模糊查询需求,优先使用搜索引擎。

解析
页面搜索严禁左模糊或者全模糊,如果需要请走搜索引擎来解决。所以C错。

多选 21.关于代码注释,下列哪些说法符合《阿里巴巴Java开发手册》:ACD

A .所有的抽象方法(包括接口中的方法)必须要用javadoc注释。
B .所有的方法,包括私有方法,最好都增加注释,有总比没有强。
C .过多过滥的注释,代码的逻辑一旦修改,修改注释是相当大的负担。
D .我的命名和代码结构非常好,可以减少注释的内容。

解析:
B错,个人感觉这句话语义上有漏洞,不是"最好"而是"必须"。
正例:【强制】类、类属性、类方法的注释必须使用 Javadoc 规范,使用/**内容*/格式,不得使用
// xxx 方式。

多选 22.关于checked/unchecked exception,下列哪些说法是正确的:BCD

A .继承java.lang.Error的类属于checked exception。
B .checked异常继承java.lang.Exception类。
C .unchecked异常继承java.lang.RuntimeException类。
D .NullPointerException , IllegalArgumentException属于unchecked exception。

解析:
1

要弄明白这个题说的是啥,首先要知道这几个概念:

运行时异常:都是RuntimeException类及其子类异常,如NullPointerException(空指针异常)、IndexOutOfBoundsException(下标越界异常)等,这些异常是不检查异常,程序中无法直接捕获的。这些异常一般是由程序逻辑错误引起的,程序应该从逻辑角度尽可能避免这类异常的发生。
运行时异常的特点是Java编译器不会检查它,也就是说,当程序中可能出现这类异常,即使没有用try-catch语句捕获它,也没有用throws子句声明抛出它,也会编译通过。

编译时异常(非运行时异常):是RuntimeException以外的异常,类型上都属于Exception类及其子类。从程序语法角度讲是必须进行处理的异常,如果不处理,程序就不能编译通过。如IOException、SQLException等以及用户自定义的Exception异常。

检查型异常(Checked Exception):所谓检查(Checked)是指编译器要检查这类异常,检查的目的一方面是因为该类异常的发生难以避免,另一方面就是让开发者去解决掉这类异常,所以称为必须处理(try ...catch)的异常。如果不处理这类异常,集成开发环境中的编译器一般会给出错误提示。

非检查型异常(Unchecked Exception):所谓非检查(Unchecked)是指编译器不会检查这类异常,不检查的则开发者在代码的编辑编译阶段就不是必须处理,这类异常一般可以避免,因此无需处理(try ...catch)。如果不处理这类异常,集成开发环境中的编译器也不会给出错误提示。
所以可以知道,运行时异常即非检查型异常,编译时异常即检查型异常。

单选 23.关于Map类型集合的遍历方式,下列哪些说法是正确的:D

A .Map类型的实现类都同时实现了Iterator接口。
B .使用foreach进行遍历。
C .推荐使用keySet进行遍历。
D .推荐使用entrySet进行遍历。

解析:

【推荐】
使用 entrySet 遍历 Map 类集合 KV,而不是 keySet 方式进行遍历。
说明:keySet 其实是遍历了 2 次,一次是转为 Iterator 对象,另一次是从 hashMap 中取出
key 所对应的 value。而 entrySet 只是遍历了一次就把 key 和 value 都放到了 entry 中,效
率更高。如果是 JDK8,使用 Map.foreach 方法。所以B错,使用foreach只是遍历方法其中的一种。

// JDK8的迭代方式
map.forEach((key, value) -> {
    System.out.println(key + ":" + value);
});

正例:values()返回的是 V 值集合,是一个 list 集合对象;keySet()返回的是 K 值集合,是
一个 Set 集合对象;entrySet()返回的是 K-V 值组合集合。

多选 24.关于变量、方法名、包的命名,下列哪些说法符合《阿里巴巴Java开发手册》:ABCD

A .POJO类中的任何布尔类型的变量,都不要加is,因为部分框架解析时有可能会出现序列化错误。
B .包名统一使用单数形式,如:com.alibaba.mpp.util。
C .中括号是数组类型的一部分,数组定义如下:String[] args; 不要误写为String args[];
D .Service/DAO层方法命名可以参考规约,例如:删除的方法推荐使用remove或delete做前缀。

多选 25.关于常量定义,下列哪些说法符合《阿里巴巴Java开发手册》:AC

A .不允许出现任何魔法值(即未经预先定义的常量)直接出现在代码中。
B .魔法值是指程序中随意定义并赋值的变量值,如果代码编写者明白变量值意义是可以任意使用的,例如在代码中写if(status == 3) return error;符合规范。
C .如果变量值仅在一个范围内变化推荐用Enum类。
D .在程序中,一律禁止使用枚举类型。

解析
【推荐】如果变量值仅在一个固定范围内变化用 enum 类型来定义。(使用枚举类的条件)
【强制】不允许任何魔法值(即未经预先定义的常量)直接出现在代码中。
【强制】二方库里可以定义枚举类型,参数可以使用枚举类型,但是接口返回值不允许使用枚
举类型或者包含枚举类型的 POJO 对象

多选 26.关于maven依赖、仲裁、规则,下列哪些说法是正确的:ACD

A .<dependencies>的依赖会默认传递给子项目。
B .<dependencies>的依赖绝对不会传递给子项目。
C .在<dependencyManagement>中指定版本号。
D .避免在不同的子项目,声明同一个二方库的不同版本号。

解析
【推荐】所有 pom 文件中的依赖声明放在<dependencies>语句块中,
所有版本仲裁放在 <dependencyManagement>语句块中。
说明:<dependencyManagement>里只是声明版本,并不实现引入,因此子项目需要显式的声
明依赖,version 和 scope 都读取自父 pom。而<dependencies>所有声明在主 pom 的 <dependencies>里的依赖都会自动引入,并默认被所有的子项目继承。 所以B错

单选 27.关于二方库升级,下列哪些说法是正确的:B

A .升级二方库只是改个版本号,不需要关联功能的回归。
B .升级二方库需要比对仲裁结果的差异,谨慎评估。
C .升级二方库,绝对不会影响到其它二方库的版本号。
D .只要此二方库负责人保证说不会有任何影响,即可大胆升级,直接发布上线。

解析
正例:二方库的新增或升级,保持除功能点之外的其它 jar 包仲裁结果不变。如果有改变,
必须明确评估和验证,建议进行 dependency:resolve 前后信息比对,如果仲裁结果完全不一
致,那么通过 dependency:tree 命令,找出差异点,进行<excludes>排除 jar 包。

多选 28.关于表字段和索引,下列哪些说法符合《阿里巴巴Java开发手册》:ABD

A .表字段注释,如果修改字段含义或对字段表示的状态追加时,需要及时更新。
B .合适的字符存储长度,不但节约数据库表空间、节约索引存储,更重要的是提升检索速度。
C .针对表的每个字段都增加索引,加快查询速度。
D .字段的区分度越高,索引的查找速度越快。

解析
【参考】创建索引时避免有如下极端误解:

1)宁滥勿缺。认为一个查询就需要建一个索引。
2)宁缺勿滥。认为索引会消耗空间、严重拖慢更新和新增速度。
3)抵制惟一索引。认为业务的惟一性一律需要在应用层通过“先查后插”方式解决。

单选 29.关于测试代码的覆盖率,下列哪些说法是正确的?B

A .路径覆盖是最强覆盖,符合路径覆盖且测试全部通过,程序绝对没有问题。
B .语句覆盖度是最弱的覆盖度量方式。
C .分支覆盖与条件覆盖其实是一回事。
D .判定条件覆盖与路径覆盖其实是一回事。

解析

举个例子吧
  if   A   and   B   then   Action1  
  if   C   or   D   then   Action2  

语句覆盖:最弱,只需要让程序中的语句都执行一遍即可。上例中只需设计测试用例使得A=true B=true C=true即可。

分支覆盖:又称判定覆盖:使得程序中每个判断的取真分支和取假分支至少经历一次,即判断的真假均曾被满足。上例需要设计测试用例使其分别满足下列条件即可

1)A=true,B=true,C=true,D=false(2)A=true,B=false,C=false,D=false
条件覆盖:要使得每个判断中的每个条件的可能取值至少满足一次。上例中第一个判断应考虑到A=true,A=false,B=true,B=false
第二个判断应考虑到C=true,C=false,D=true,D=false,所以上例中可以设计测试用例满足下列条件
(1)A=true,B=true,C=true,D=true(2)A=false,B=false,C=false,D=false

路径覆盖:要求覆盖程序中所有可能的路径。所以可以设计测试用例满足下列条件(1)A=true,B=true,C=true,D=true(2)A=false,B=false,C=false,D=false(3)A=true,B=true,C=false,D=false(4)A=false,B=false,C=true,D=true
不论哪种覆盖方法,都不能保证程序的正确性。
--来自https://www.cnblogs.com/ganmk/archive/2008/11/07/1328585.html

多选 30.Hashtable,HashMap, ConcurrentHashMap都是Map的实现类,它们在处理null值的存储上有细微的区别,下列哪些说法是正确的:ABD

A .Hashtable的KV都不可以为null。
B .HashMap的KV都可以为null。
C .HashMap的K不可以为null,V可以为null。
D .ConcurrentHashMap的KV都不可以为null。

解析

多选 31.关于数据库命名规则,下列哪些说法符合《阿里巴巴Java开发手册》:BCD

A .数据库库名和表名没有规定,可任意取名,只要方便记忆即可。
B .库名应该尽量与应用名称保持一致,表的命名最好是业务名称_表名的方式。
C .无论是库名还是表名都禁用保留字,如desc、match、range等。
D .表名、字段名必须使用小写字母或数字。
解析:
【强制】表名、字段名必须使用小写字母或数字,禁止出现数字开头,禁止两个下划线中间只
出现数字。数据库字段名的修改代价很大,因为无法进行预发布,所以字段名称需要慎重考虑。

多选 32.关于异常的处理方式,下列哪些说法是正确的:BD

A .为防止obj对象本身空指针异常,书写代码时应该注意加异常捕获处理,例如:try { obj.method() } catch(NullPointerException e){……} 。
B .方法签名中,抛给调用者的关键字为throws
C .方法内部,抛出异常实例对象为throws
D .自定义异常要做到“认知对等”,即:抛出者和接收者要保持对自定义异常的认知统一,接收方需要知道这种异常的含义和对应的处理方案。

多选 33.数组使用Arrays.asList转化为集合,下列说法哪些是正确的:ACD

A .数组元素的修改,会影响到转化过来的集合。
B .数组元素的修改,不会影响到转化过来的集合。
C .对于转换过来的集合,它的 add/remove/clear 方法会抛出: UnsupportedOperationException。
D .Arrays.asList 体现的是适配器模式,只是转换接口,后台的数据仍是数组。

解析
正例:使用工具类 Arrays.asList()把数组转换成集合时,不能使用其修改集合相关的方
法,它的 add/remove/clear 方法会抛出 UnsupportedOperationException 异常。
说明:asList 的返回对象是一个 Arrays 内部类,并没有实现集合的修改方法。Arrays.asList
体现的是适配器模式,只是转换接口,后台的数据仍是数组。

 String[] str = new String[] { "you", "wu" };
 List list = Arrays.asList(str);

第一种情况:list.add("yangguanbao"); 运行时异常。
第二种情况:str[0] = "gujin"; 那么 list.get(0)也会随之修改

多选 34.关于文件编码和格式的设定,下列哪些说法符合《阿里巴巴Java开发手册》:BC

A .IDE的text file encoding设置为GBK格式。
B .IDE的text file encoding设置为UTF-8格式。
C .IDE中文件的换行符使用unix格式。
D .IDE中文件的换行符使用windows格式。

多选 35.关于数据库是与否概念的列的命名方式,下列哪些说法符合《阿里巴巴Java开发手册》:BD

A .对于是与否概念的列名,必须使用can_abc 来表示。
B .对于是与否概念的列名,必须使用is_abc 来表示。
C .数据类型是varchar(1)( Y表示是,N表示否)。
D .数据类型是unsigned tiny int.( 1表示是,0表示否)。

多选 36.以下关于格式规约的说法,正确的有哪些:AD

A .代码块缩进4个空格,如果使用tab缩进,请设置成1个tab为4个空格;
B .代码块缩进5个空格,如果使用tab缩进,请设置成1个tab为5个空格。
C .为了保持代码美观,《手册》强烈推荐增加若干空格,使某一行的变量与相邻对应位置的变量对齐。
D .方法体内的执行语句组、变量的定义语句组、不同的业务逻辑之间或者不同的语义之间推荐插入一个空行;相同业务逻辑和语义之间不需要插入空行。

多选 37.通过集合A.subList()获取子集合B,下列说法哪些是正确的:ABD

A .返回的集合B没有实现Serializable接口,不能被序列化,所以不能应用于RPC场景。
B .在B集合中添加某个元素,那么A集合也会添加进去此元素。
C .集合A中元素的修改不会影响到集合B的任何操作。
D .对A元素个数的修改,会导致集合B的遍历产生ConcurrentModificationException 异常。

多选 38.关于捕获异常和抛异常,下列哪些说法符合《阿里巴巴Java开发手册》:BCD

A .如果需要捕获不同类型异常,为了方便处理,可以使用catch(Exception e){...}。
B .不要捕获异常后不处理,丢弃异常信息。
C .捕获异常与抛异常,必须是完全匹配,或者捕获异常是抛异常的父类。
D .异常定义时区分unchecked / checked 异常,避免直接使用RuntimeException抛出。

解析:正例:catch 时请分清稳定代码和非稳定代码,稳定代码指的是无论如何不会出错的代码。
对于非稳定代码的 catch 尽可能进行区分异常类型,再做对应的异常处理。
说明:对大段代码进行 try-catch,使程序无法根据不同的异常做出正确的应激反应,也不利
于定位问题,这是一种不负责任的表现。

多选 39.关于线程安全,下列哪些说法是正确的:ACD

A .SimpleDateFormat 是线程不安全的类。
B .SimpleDateFormat 是线程安全的类。
C .一般不要定义SimpleDateFormat的static变量,如果定义为static,必须保证线程安全。
D .推荐使用Apache封装好的DateUtils和DateFormatUtils工具类,来处理时间日期转换问题。

解析:正例:SimpleDateFormat 是线程不安全的类,一般不要定义为 static 变量,如果定义为
static,必须加锁,或者使用 DateUtils 工具类。如果是 JDK8 的应用,可以使用 Instant 代替 Date,LocalDateTime 代替 Calendar,
DateTimeFormatter 代替 SimpleDateFormat,官方给出的解释:simple beautiful strong
immutable thread-safe。

多选 40.为了更方便地进行单元测试,被测试的业务代码应避免以下哪些情况?ABCD

A .构造方法中做的事情过多。
B .存在过多的全局变量和静态方法。
C .存在过多的外部依赖。
D .存在过多的条件语句。

多选 41.关于控制语句,下列哪些说法符合《阿里巴巴Java开发手册》:ABD

A .推荐 if-else的方式可以改写成卫语句的形式。
B .尽量减少try-catch 块内的逻辑,定义对象、变量、获取数据库连接等操作可以移到try-catch块外处理
C .if ( condition) statements; 单行语句不需要使用大括号。
D .在一个switch块内,都必须包含一个default语句并且放在最后,即使它什么代码也没有。

多选 42.关于参数有效性验证,下列哪些说法符合《阿里巴巴Java开发手册》:ABCD

A .防止page size过大导致内存溢出。
B .防止正则输入源串拒绝服务ReDOS。
C .防止任意重定向。
D .预防 SQL 注入。

多选 43.关于变量和常量定义,下列哪些符合《阿里巴巴Java开发手册》:AD

A .Long a=2L;//大写的L
B .Long a=2l; //小写的l
C .常量只定义一次,不再赋值,所以不需要命名规范。
D .不要使用一个常量类维护所有常量,应该按常量功能进行归类,分开维护。

单选 44.在定义DO/DTO/VO/等POJO类时,对属性默认值的设定,下列哪些说法符合《阿里巴巴Java开发手册》:D

A .String类型的默认值设定为空字符串。
B .Date类型的默认值设定为new Date()。
C .集合类型的默认值设定为Collections.EMPTY_LIST。
D .不要设定任何属性默认值。

多选 45.关于二方库依赖的解析命令,下列哪些说法是正确的:ABC

A .mvn dependency:resolve 打印出已仲裁依赖的列表。
B .mvn dependency:tree 打印工程整个的依赖树结构。
C .mvn dependency:tree -Dverbose -Dincludes=commons-lang 打印出与commons-lang相关的详细依赖。
D .mvn clean install 打印工程整个的依赖树结构,并部署到本地仓库中。

单选 46.KV结构的集合,在处理null值的存储上有细微的区别,下列哪些说法是正确的:A

A .TreeMap的key不可以为null
B .TreeMap的key可以为null
C .ConcurrentHashMap的key可以为null
D .ConcurrentHashMap的value可以为null

多选 47.关于数据库中表相关的命名,下列哪些说法符合《阿里巴巴Java开发手册》:ABD

A .表名、字段名禁止出现数字开头,禁止两个下划线中间只出现数字。
B .表名不使用复数名词。
C .表必备三字段命名:id, gmt_create, gmt_modify。
D .表必备三字段命名:id, gmt_create, gmt_modified。

多选 48.关于多线程并行处理定时任务的情况,下列哪些说法符合《阿里巴巴Java开发手册》:BCD

A .推荐使用Timer方式处理。
B .推荐使用ScheduledExecutorService方式处理。
C .Timer运行多个TimeTask时,只要其中之一没有捕获抛出的异常,其它任务便会自动终止运行。
D .ScheduledExecutorService并发运行多个定时任务时,其中某线程抛出异常,不会影响到其它线程的继续运行。

解析:正例:多线程并行处理定时任务时,Timer 运行多个 TimeTask 时,只要其中之一没有捕获
抛出的异常,其它任务便会自动终止运行,使用 ScheduledExecutorService 则没有这个问题。

多选 49.关于Java代码的设计和开发注意事项,下列哪些说法符合《集合开发规约》:ABCD

A .禁止将URL、文件名、系统参数、数据库连接地址、业务规则的可变参数,硬编码在工程中。
B .long或者Long初始赋值时,必须是大写的L,不能小写。
C .当一个类有多个构造方法,或是多个同名方法,这些方法应该按顺序放置在一起,便于阅读。
D .相同参数类型,同等业务含义,才可以使用Java的可变参数,参数的类型尽量避免使用Object。

多选 50.关于数据库索引的命名,下列哪些说法符合《阿里巴巴Java开发手册》:ACD

A .主键索引(primary key),字段类型为unsigned bigint、单表时推荐自增、步长为1。
B .主键索引(primary key),字段类型为unsigned bigint、单表时推荐自增、步长为2。
C .唯一索引(unique key),命名规则为uk_字段名(如果多个字段继续下划线)。
D .普通索引(normal index),标记成idx_字段名(如果多个继续下划线)。

多选 51.关于Java代码的设计和开发注意事项,下列哪些说法符合《阿里巴巴Java开发手册》:ABC

A .所有的覆写方法,必须是强制加 @Override。
B .setter方法中,参数名称与类成员变量名称一致,this.成员名=参数名。
C .在getter方法中,尽量不要增加逻辑判断,因为添加了逻辑判断后,会增加排查问题难度。
D .避免用BeanUtil进行属性的copy。
解析: 避免用Apache Beanutils进行属性的copy。 说明:Apache BeanUtils性能较差,可以使用其他方案比如Spring BeanUtils, Cglib BeanCopier。

  TestObject a = new TestObject();
    TestObject b = new TestObject();
    a.setX(b.getX());
    a.setY(b.getY());

多选 52.在多线程并发读写的情况下,下列哪些处理方式能保证对象的线程安全:BCD

A .使用volatile关键字。
B .使用synchronized关键字给对象的读写操作加锁。
C .如果是基本类型,推荐使用java.util.concurrent.atomic包下面提供的线程安全的基本类型包装类,例如AtomicInteger。
D .如果是集合,推荐使用java.util.concurrent提供的并发集合类,例如:ConcurrentHashMap。
解析:
volatile 解决多线程内存不可见问题。对于一写多读,是可以解决变量同步问题,
但是如果多写,同样无法解决线程安全问题。

多选 53.关于代码书写格式,下列哪些说法符合《阿里巴巴Java开发手册》:BCD

A .换行时相对上一行缩进2个空格。
B .运算符与下文一起换行,方法调用的点符号与下文一起换行。
C .在多个参数超长,逗号后进行换行。
D .在括号前不要换行。
解析:

阿里规约:【强制】单行字符数限制不超过 120 个,超出需要换行,换行时遵循如下原则:
1) 第二行相对第一行缩进 4 个空格,从第三行开始,不再继续缩进,参考示例。
2) 运算符与下文一起换行。
3) 方法调用的点符号与下文一起换行。
4) 方法调用中的多个参数需要换行时,在逗号后进行。 5) 在括号前不要换行,见反例。

正例:

StringBuffer sb = new StringBuffer(); 
// 超过 120 个字符的情况下,换行缩进 4 个空格,点号和方法名称一起换行
sb.append("zi").append("xin")... 
.append("huang")... 
.append("huang")... 
.append("huang");

单选 54.关于使用explain对数据库性能进行优化分析,下列哪些说法符合《阿里巴巴Java开发手册》:A

A .SQL性能优化的目标:至少要达到 range 级别,要求是ref级别,如果可以是consts最好。
B .index级别走的是扫描索引,所以速度会比ref快。
C .range级别是指对表进行范围索引。
D .ref级别是指使用主键或者唯一索引。
解析:
【推荐】SQL 性能优化的目标:至少要达到 range 级别,要求是 ref 级别,如果可以是 consts最好。
说明:
1)consts 单表中最多只有一个匹配行(主键或者唯一索引),在优化阶段即可读取到数据。
2)ref 指的是使用普通的索引(normal index)。
3)range 对索引进行范围检索。

多选 55.关于索引效率,下列哪些说法符合《阿里巴巴Java开发手册》:CD

A .使用索引的效率一定高于全表扫描的效率。
B .关于explain的结果,type=index的索引效率好于type=ref。
C .sql查询条件 where a like ‘%阿里%’ ,不会走索引。
D .sql查询条件 where a like ‘阿里%’ ,a列创建了索引,一般会使用索引进行检索。
解析:
索引会失效不走索引的场景,例如where 条件后的字段不能使用函数运算;like 的左模糊和全模糊;索引字段的隐式转换等。
索引type的级别优先级:system > const > eq_ref > ref > range > index > ALL

多选 56.关于线程池管理线程的好处,下列哪些说法是正确的:AC

A .能够减少在创建和销毁线程上所花的时间以及系统资源的开销。
B .使用线程池一定能避免OOM问题。
C .线程资源必须通过线程池提供,不允许在应用中自行显式创建线程。
D .线程池能够根据资源等待情况,自动调整线程优先级并解决死锁问题。
解析:

阿里巴巴规约:【强制】线程资源必须通过线程池提供,不允许在应用中自行显式创建线程。
说明:使用线程池的好处是减少在创建和销毁线程上所消耗的时间以及系统资源的开销,解决
资源不足的问题。如果不使用线程池,有可能造成系统创建大量同类线程而导致消耗完内存或
者“过度切换”的问题。

多选 57.关于用日志记录异常信息,下列哪些说法符合《阿里巴巴Java开发手册》:AB

A .日志尽量记录案发现场信息和异常堆栈信息。
B .如果日志中输出POJO类,POJO类需要重写toString方法,避免只输出hashCode。
C .不建议输出任何日志,因为日志记录消耗性能。
D .捕获异常后,一律抛给调用者去处理。
解析:

阿里巴巴规约:【推荐】谨慎地记录日志。生产环境禁止输出 debug 日志;有选择地输出 info 日志;如果使
用 warn 来记录刚上线时的业务行为信息,一定要注意日志输出量的问题,避免把服务器磁盘
撑爆,并记得及时删除这些观察日志。
说明:大量地输出无效日志,不利于系统性能提升,也不利于快速定位错误点。

据此知道,日志记录影响性能,需要节制使用,但也不可或缺。

多选 58.关于应用与数据库之间的操作,下列哪些说法符合《阿里巴巴Java开发手册》:BC

A .对外提供一个大而全的接口进行POJO的update更新,这样比较省事,省代码。
B .使用事务回滚的地方需要考虑各方面的回滚方案,包括缓存回滚、搜索引擎回滚、消息补偿、统计修正等。
C .应用服务器与数据库之间是短连接。
D .应用服务器与数据库之间是长连接。
解析:

阿里巴巴规约【推荐】不要写一个大而全的数据更新接口。传入为 POJO 类,不管是不是自己的目标更新字段,都进行 update table set c1=value1,c2=value2,c3=value3; 这是不对的。执行 SQL时,不要更新无改动的字段,一是易出错;二是效率低;三是增加 binlog 存储。 应用服务器与数据库之间是短连接,短连接是指程序和数据库通信时需要建立连接,执行操作后,连接关闭。短连接简单来说就是每一次操作数据库,都要打开和关闭数据库连接,基本步骤是:连接→数据传输→关闭连接。

【参考】@Transactional 事务不要滥用。事务会影响数据库的 QPS,另外使用事务的地方需要考虑各方面的回滚方案,包括缓存回滚、搜索引擎回滚、消息补偿、统计修正等。

多选 59.关于二方库的依赖处理,下列哪些说法符合《阿里巴巴Java开发手册》:ACD

A .依赖于一个二方库群时,必须定义一个统一版本变量,避免各子二方库版本号不一致。

B .可以允许子项目的pom依赖中出现相同的GroupId,相同的ArtifactId,但是不同的Version。

C .所有pom文件中的依赖声明放在语句块中,所有版本仲裁放在语句块中。

D .线上应用不要依赖SNAPSHOT版本(安全包除外)。

解析:

【强制】禁止在子项目的 pom 依赖中出现相同的 GroupId,相同的 ArtifactId,但是不同的 Version。

 【强制】依赖于一个二方库群时,必须定义一个统一的版本变量,避免版本号不一致。

【强制】线上应用不要依赖 SNAPSHOT 版本(安全包除外)。

说明:不依赖 SNAPSHOT 版本是保证应用发布的幂等性。另外,也可以加快编译时的打包构建。

单选 60.sort表示元素在存入集合时进行了排序,数据遍历的结果是按某个排序规则输出的; 而order表示每次遍历的序列都是一样的,元素前后关系每次遍历都是确定的,那么下列哪些集合既是sort,又是order的:D

A .HashSet
B .LinkedList
C .HashMap
D .TreeSet

解析:

【参考】合理利用好集合的有序性(sort)和稳定性(order),避免集合的无序性(unsort)和
不稳定性(unorder)带来的负面影响。

说明:有序性是指遍历的结果是按某种比较规则依次排列的。稳定性指集合每次遍历的元素次
序是一定的。如:ArrayList 是 order/unsort;HashMap 是 unorder/unsort;TreeSet 是order/sort。

多选 61.关于工具类二方库已经提供的,尽量不要在本应用中编程实现,下列哪些说法符合《阿里巴巴Java开发手册》:ABD

A .json操作使用fastjson。
B .md5操作使用commons-codec。
C .ArrayUtils、NumberUtils、DateFormatUtils、DateUtils等优先使用org.apache.commons.lang包。
D .CollectionUtils优先使用org.apache.commons.collections4包。

解析:
【参考】为避免应用二方库的依赖冲突问题,二方库发布者应当遵循以下原则:
1)精简可控原则。移除一切不必要的 API 和依赖,只包含 Service API、必要的领域模型对象、Utils 类、常量、枚举等。
如果依赖其它二方库,尽量是 provided 引入,让二方库使用者去依赖具体版本号;无 log 具体实现,只依赖日志框架。

2)稳定可追溯原则。每个版本的变化应该被记录,二方库由谁维护,源码在哪里,都需要能
方便查到。除非用户主动升级版本,否则公共二方库的行为不应该发生变化。

多选 62.关于类和方法的命名,下列哪些说法符合《阿里巴巴Java开发手册》:ABD

A .类名使用UpperCamelCase命名法,但是领域模型命名除外,如:ProductDO的命名是规范的。
B .方法名命名应该使用lowerCamelCase命名法,如方法名:getHttpMessage() 是符合命名规范的。
C .为了方便理解,方法名或参数名可以使用拼音与英文混合的方式。
D .所有编程相关的命名均不能以下划线或美元符号开始,也不能以下划线或美元符号结束。
解析:
【强制】类名使用 UpperCamelCase 风格,但以下情形例外:DO / BO / DTO / VO / AO / PO / UID 等。(领域模型)
【强制】代码中的命名严禁使用拼音与英文混合的方式,更不允许直接使用中文的方式。
【强制】代码中的命名均不能以下划线或美元符号开始,也不能以下划线或美元符号结束。

多选 63.对于索引(a, b, c),下列哪些说法是正确的:ABC

A .查询语句 where a between 5 and 10 可以使用该索引。
B .查询语句 where a = 5 and b between 5 and 10 可以使用该索引。
C .查询语句 where a in (5, 6, 7, 8, 9) and b = 5 可以使用该索引。
D .查询语句 where b = 5 and c = 10 可以使用该索引。

解析:知识点索引做前缀。

多选 64.以下关于命名规约内容说明,正确的是:BCD

A .【强制】包名统一使用小写,点分隔符之间有且仅有一个自然语义的英语单词,并且使用复数形式,例如:应用工具类包名为com.alibaba.mpp.utils
B .【强制】类名使用UpperCamelCase,必须遵从驼峰形式,但以下情形例外:(领域模型的相关命名)DO / DTO / VO / DAO等。
C .【强制】抽象类命名使用Abstract或Base开头;异常类命名使用Exception结尾;测试类命名以它要测试的类的名称开始,以Test结尾。
D .【强制】枚举类名建议带上Enum后缀,枚举成员名称需要全大写,单词间用下划线隔开。
解析:
【强制】包名统一使用小写,点分隔符之间有且仅有一个自然语义的英语单词。包名统一使用
单数形式,但是类名如果有复数含义,类名可以使用复数形式。
总结记忆口诀:
包名单数类复数,
类名使用大驼峰,
抽象Abstract或Base开头,
异常当然Exception结尾,
测试必须Test结尾。

多选 65.根据《阿里巴巴Java开发手册》,以下哪些字段属于表的必备字段:ABD

A .id
B .gmt_modified
C .parent_id
D .gmt_create

单选 66.单元测试代码写在Java工程的哪个地方最为合适?C

A .写在业务代码体里边,方便调试。
B .写在业务代码同一个包下,方便归类查找。
C .写在src/test/java目录下。
D .写在src/java目录下。

多选 67.编写单元测试代码遵守BCDE原则,以保证被测试模块的交付质量,那么下列说法正确的是:ABC

A .Border,边界值测试,包括循环边界、特殊取值、特殊时间点、数据顺序等。
B .Correct,正确的输入,并得到预期的结果。
C .Design,与设计文档相结合,来编写单元测试。
D .Equal, 单元测试环境必须与线上生产环境一致。
解析:
【推荐】编写单元测试代码遵守 BCDE 原则,以保证被测试模块的交付质量。
B:Border,边界值测试,包括循环边界、特殊取值、特殊时间点、数据顺序等。
C:Correct,正确的输入,并得到预期的结果。
D:Design,与设计文档相结合,来编写单元测试。
E:Error,强制错误信息输入(如:非法数据、异常流程、非业务允许输入等),并得
到预期的结果。

多选 68.关于领域模型命名,下列哪些说法符合《阿里巴巴Java开发手册》:ABC

A .数据对象命名:xxxDO,xxx即为数据表名,例如:ResellerAccountDO。
B .数据传输对象:xxxDTO,xxx为业务领域相关的名称,例如ProductDTO。
C .展示层对象:xxxVO,xxx一般为网页名称,例如RecommendProductVO。
D .POJO是DO/DTO/BO/VO的统称,命名成xxxPOJO。

解析:

【参考】各层命名规约:
A) Service/DAO 层方法命名规约
1) 获取单个对象的方法用 get 做前缀。
2) 获取多个对象的方法用 list 做前缀,复数形式结尾如:listObjects。
3) 获取统计值的方法用 count 做前缀。
4) 插入的方法用 save/insert 做前缀。
5) 删除的方法用 remove/delete 做前缀。
6) 修改的方法用 update 做前缀。

B) 领域模型命名规约
1) 数据对象:xxxDO,xxx 即为数据表名。
2) 数据传输对象:xxxDTO,xxx 为业务领域相关的名称。
3) 展示对象:xxxVO,xxx 一般为网页名称。
4) POJO 是 DO/DTO/BO/VO 的统称,禁止命名成 xxxPOJO。

多选 69.关于客户数据展示,下列哪些说法符合《阿里巴巴Java开发手册》:ABCD

A .客户的密码,密钥及密保问题答案等信息禁止展示。
B .客户的银行卡号只显示后四位。
C .客户的证件号码只显示第一位和最后一位,在必要业务
D .涉及有完整展示客户信息的页面均需要接入防爬系统
解析:

【强制】用户敏感数据禁止直接展示,必须对展示数据进行脱敏。
说明:中国大陆个人手机号码显示为:158****9119,隐藏中间 4 位,防止隐私泄露。


常见考点:

【推荐】常量的复用层次有五层:跨应用共享常量、应用内共享常量、子工程内共享常量、包

内共享常量、类内共享常量。
1) 跨应用共享常量:放置在二方库中,通常是 client.jar 中的 constant 目录下。
2) 应用内共享常量:放置在一方库中,通常是子模块中的 constant 目录下。
3) 子工程内部共享常量:即在当前子工程的 constant 目录下。
4) 包内共享常量:即在当前包下单独的 constant 目录下。
5) 类内共享常量:直接在类内部 private static final 定义。

【强制】定义 GAV 遵从以下规则:

1) GroupID 格式:com.{公司/BU }.业务线 [.子业务线],最多 4 级。
2) ArtifactID 格式:产品线名-模块名。语义不重复不遗漏,先到中央仓库去查证一下。
3) Version:详细规定参考下方。

【参考】分层领域模型规约:

1) DO(Data Object):此对象与数据库表结构一一对应,通过 DAO 层向上传输数据源对象。
2) DTO(Data Transfer Object):数据传输对象,Service 或 Manager 向外传输的对象。
3) BO(Business Object):业务对象,由 Service 层输出的封装业务逻辑的对象。
4) AO(Application Object):应用对象,在 Web 层与 Service 层之间抽象的复用对象模型,
极为贴近展示层,复用度不高。
5) VO(View Object):显示层对象,通常是 Web 向模板渲染引擎层传输的对象。
6) Query:数据查询对象,各层接收上层的查询请求。注意超过 2 个参数的查询封装,禁止
使用 Map 类来传输。

【强制】线上应用不要依赖 SNAPSHOT 版本(安全包除外)。

说明:不依赖 SNAPSHOT 版本是保证应用发布的幂等性。另外,也可以加快编译时的打包构建。

【强制】安全规约(必看,这里略,详情参考《阿里巴巴java开发手册》)


参考:https://blog.csdn.net/shiliang97/article/details/104693281

posted @ 2021-08-05 14:07  Jsonring  阅读(5121)  评论(0编辑  收藏  举报
分享到: