JAVA编码规范试题3.docx
《JAVA编码规范试题3.docx》由会员分享,可在线阅读,更多相关《JAVA编码规范试题3.docx(16页珍藏版)》请在冰豆网上搜索。
JAVA编码规范试题3
一、判断题(每题2分,共28分)
1.为了程序更加简洁,我们应该尽量使用下面的方式来赋值:
a=b=1;错
2.每个类都需要定义构建器;错
3.使用ObjectStream的方法后,调用release(),释放对象;错调用reset(),释放对象
4.不能用异常来做一般流程处理的方式,不要过多地使用异常,异常的处理效率比条件分支低,而且异常的跳转流程难以预测。
对
5、没有被覆盖的友好方法和没有子类的友好类应该定义成final。
对6、简单的类可以通过名字比较两个对象的类,推荐使用getClass()或者instanceof()。
错
7、不要调用Thread类的resume(),suspend(),sleep(),stop()方法。
8、判断方法是否是重载,只关注方法名、参数个数、参数类型,不关注方法返回值;对
9、类注释部分,描述部分说明该类或者接口的功能、作用、使用方法和注意事项,每次修改后增加作者、新版本号和当天的日期,@since表示从那个版本开始就有这个类或者接口,@deprecated表示不建议使用该类或者接口。
10、对于方法内部用throw语句抛出的异常,必须在方法的注释中标明;对于所调用的其他方法所抛出的异常,在注释中要求说明所有的异常;对于非RuntimeException,即throws子句声明会抛出的异常,必须在方法的注释中标明。
11.相对独立的程序块之间、变量说明之后必须加行空行;对
12.任何时候都不要使接口可以序列化;对
13.减小单个方法的复杂度,使用的if,while,for,swith语句要在10个以内;对
14.main()方法的定义是publicstaticvoidmain(Stringargs[]);错
二、单选题(每题2分,共36分)
1下列错误使用异常的做法是(D)
A.在程序中使用异常处理还是使用错误返回码处理,根据是否有利于程序结构来确定,并且异常和错误码不应该混合使用,推荐使用异常。
B.一个方法不应抛出太多类型的异常。
throws/exception子句标明的异常最好不要超过三个。
C.异常捕获尽量不要直接catch(Exceptionex),应该把异常细分处理。
D.程序内抛出的异常本身就可说明异常的类型、抛出条件,可不填写详细的描述信息。
捕获异常后用exception.toString()取到详细信息后保存。
2下列说法错误的是:
C
A.段代码各语句之间有实质性关联并且是完成同一件功能的,那么可考虑把此段代码构造成一个新的方法。
B.源程序中关系较为紧密的代码应尽可能相邻。
C.程序中可同时使用错误码和异常进行处理,推荐使用异常。
D.方法参数建议不超过5个。
3下面对类、方法、属性的说法不符合编程规范的有:
A.不要覆盖父类的私有方法。
B.类中不要使用非私有的非静态属性。
C.
类定义
{
类的私有属性定义
类的公有属性定义
类的保护属性定义
类的私有方法定义
类的公有方法定义
类的保护方法定义
}
D.类私有方法的最大规模建议为15个
4下面的程序片断符合JTest规范的是(B)
A.
for(inti=0;i{Appleapple=array[i];}B.publicinterfaceServiceConst{intMAX_BLACK_SIZE=100;C.For(inti=0;i{list.add(FruitFactory.getInstance().createApple());}D.Stringlog=message+“Y”;5.排版时,代码缩进应该采用的方式是(C)ATab缩进B2个空格缩进C4个空格缩进D8个空格缩进6.关于复杂度,下面那句话是错误的:AA继承层次建议不要超过5层B方法行数建议在10-50行C方法参数建议不要超过5个D类的行数不要超过1000行7下列说法错误的是(D)A.尽可能的使用局部变量进行运算。B.不要使用静态集合,其内存占用增长没有边界。C.一个只有abstract方法、finalstatic属性的类应该定义成接口。C.使用while(),sleep()代替wait(),notify()。8下面说法错误的是(D)A.属性名不能与方法名相同。B.方法重载的时候,一定要注意方法名相同。C.方法的参数名不要和类中的方法名相同。D.使用equals()比较两个类是否相同。9下列关于注释说法正确的是CA包注释可有可无,一般大家都是看类注释和方法注释B可以把一个类的类注释改为它的文件注释C类注释应该放在package关键字之后,class或者interface关键字之前D文件注释应该使用javadoc定义的方式注释,保证能够被收集并形成doc文档10关于安全,下面那句话是正确的:DA任何时候都不要使用内部类B任何时候都不要使类可以克隆C任何时候不要使接口可以序列化D为方法、属性和类定义明确的存取控制,并且尽量不要使用友好方法、属性和类11于说法正确的是:DA.使用StringBuffer的时候设置初始容量,推荐设置为1024。B.使用StringBuffer代替StringC.在国际化相关的处理逻辑,不要使用String。D.不要通过名字比较两个对象的类,应该使用instanceof()E.类调用方法的最大规模建议不超过20个。12列关于finalize()的描述错误的有:DA.在finalize。方法中一定要调用super.finalize()方法B.在finalize()方法中的finally中调用super.finalize()方法;C.不要在finalize()方法中删除监听器(Listeners);D.可以在finalize()方法中删除监听器(Listeners);13下列错误使用异常的做法是(D)A.在程序中使用异常处理还是使用错误返回码处理,根据是否有利于程序结构来确定,并且异常和错误码不应该混合使用,推荐使用异常。B.一个方法不应抛出太多类型的异常。throws/exception子句标明的异常最好不要超过三个。C.异常捕获尽量不要直接catch(Exceptionex),应该把异常细分处理。D.程序内抛出的异常本身就可说明异常的类型、抛出条件,可不填写详细的描述信息。捕获异常后用exception.toString()取到详细信息后保存。14、下列说法错误的是:A.段代码各语句之间有实质性关联并且是完成同一件功能的,那么可考虑把此段代码构造成一个新的方法。B.源程序中关系较为紧密的代码应尽可能相邻。C.程序中可同时使用错误码和异常进行处理,推荐使用异常。D.方法参数建议不超过5个。15下面的选项与公司的排版规范不相符的是A.如果语句已足够清晰则括号内侧(即左括号后面和右括号前面)不需要加空格,多重括号间不必加空格,因为在Java语言中括号已是最清晰的标志了。B.DatabaseKeyservicekey=null;key=getServiceKey();currentEventsCount=getCurrentEventsCount();if(currentEventsCount>0){//...programcode}C.if(writeToFile){writeFileThread.interrupt();}D.if((a>=b)&&(c>d)){//programcode}E.在长语句中,如果需要加的空格非常多,那么应该保持整体清晰,而在局部不加空格。给操作符留空格时不要连续留两个以上空格16下面说法或者语句不符合公司编程规范的排版要求的是:A.逗号、分号只在后面加空格;比较操作符,赋值操作符"="、"+=",算术操作符"+"、"%",逻辑操作符"&&"、"&",位域操作符"<<"、"A"等双目操作符的前后加空格;"!"、"〜"、"++"、"--"、"&"(地址运算符)等单目操作符前后不加空格;B.a*=2;C.x=y&z;D.key--;17有关各种注释内容,描述错误的是:A.成员变量注释内容:成员变量的意义、目的、功能,可能被用到的地方。B.公有和保护方法注释内容:列出方法的一句话功能简述、功能详细描述、作者、输入参数、输出参数、返回值、违例等。C.类和接口的注释内容:类的注释主要是一句话功能简述、功能详细描述,可根据需要列出:版本号、生成日期、作者、内容、功能、与其它类的关系等。如果一个类存在Bug,请如实说明这些Bug。D.文件注释内容有:文件名、版权说明、描述信息、生成日期、修改历史。E.包的注释内容:简述本包的作用、详细描述本包的内容、产品模块名称和版本、公司版权。18下面说法正确的是:A.编写代码边注释,修改代码同时修改相应的注释,以保证注释与代码的一致性。不再有用的注释不要删除,使用@deprecated表示此注释无效。B.避免在注释中使用缩写,特别是不常用缩写;但是,注释也是可使用缩写,在使用缩写时或之前,应对缩写进行必要的说明。C.在程序块的结束行下方加注释标记,以表明某程序块的结束。D.注释应考虑程序易读及外观排版的因素,使用的语言若是中、英兼有的,根据公司国际化的趋势,建议多使用英文。三、多选题(每题3分,共36分)1、下面的程序片断不符合编码规范的有:A.privatefinalstaticintTRUNK_BUSY=1;privatefinalstaticintTRUNK_UNKNOWN=-1;publicintwriteToDatabase(){...//programcodeif(state==TRUNK_IDLE){state=TRUNK_BUSY;...//programcodereturn0;else{state=TRUNK_UNKNOWN;return-1;}}B.privatevoidinitializePool(intcount)throwsException{//programcodetry{//programcode}catch(OutOfMemoryErrorex){thrownewError(ex.toString());}}C.if((a|b)&&(a&c))D.rect.length=10;context.phoneNumber=callData.getPhoneNumber();rect.width=5;2、下面描述中符合公司编程规范的说法有:A.不要使用空的for、if、while语句。B.在switch中每个case语句都应该包含break或者return。C.在运算中允许减小数据的精度,在赋值过程要进行强制转型操作。D.switch语句中的case关键字要和后面的常量保持一个空格,switch语句中不要定义case之外的无用标签。E.尽量显式初始化所有的静态属性,但是对于int、char等等非Object属性,都有默认值,可以不进行初始化。3、对包的命名,下面正确的是:Acom.huawei.产品名.模块名称Bcom.huawei.开发组名称.项目名称Ccom.huawei.部门名称.模块名称Dcom.huawei.部门名称.项目名称4、关于String和StringBuffer,下面哪些是正确的A常量字符串使用String,非常量字符串使用StringBufferB使用StringBuffer的时候设置初始容量C尽量使用StringTokenizer代替indexOf()和substring()C尽量不要使用StringBuffer,StringTokenizer类5、下列使用异常的错误的是A.程序发生了致命的错误,抛出一个ERROR!误通知虚拟机。B.程序必须足够健壮,在有可能抛出ERRO错误的地方,将其捕获处理,以免错误扩散C.运行期异常是程序在运行过程中本身考虑不周导致的异常,程序设计之初考虑不周是难免的,设计时应该定义RuntimeException的子类表示这种异常。D.方法内可能抛出的异常必须在方法声明上加throws子句。6、下面的做法符合公司的编程规范要求的有:A.明确方法功能,精确或近似地实现方法设计。一个函数仅完成一件功能,即使简单功能也应该编写方法实现。B.应明确规定对接口方法参数的合法性检查应由接口方法本身负责还是由方法的调用者负责,缺省是由后者负责。C.注释的原则是有助于对程序的阅读理解,如果一个类存在Bug,要如实说明这些Bug。D.父类如果实现了比较合理的toString(),子类可以继承不必再重写toString()。E.数据库操作、IO操作等需要使用结束close()的对象必须在try-catch-finally的finally中close()<7、下列程序片断符合编码规则的有:A.try{//...程序}catch(NullPointExceptionex){Log.doLog(ex.getMessage());}B.publicvoidsubscribe(intid){//programcodeSystem.out.println("Result:"+id+"subscribesucceed")//programcode}C.publicvoidsubscribe(intid){//programcodeLogManager.info("Result:"+id+"subscribeissucceed")}D.try{}catch(ServiceExceptionioe){LogManager.warn(ioe);}8下面哪些符合公司的编程规范的注释要求的有:A.文件注释:/*文件名:LogManager.java描述:WINV200R002WEBSMAP通用日志系统修改人:张三修改时间:2001-02-16修改内容:新增*/B.类注释:/***LogManager类集中控制对日志读写的操作。*全部为静态变量和静态方法,对外提供统一接口。分配对应日志类型的读写器,*读取或写入符合条件的日志纪录。*@author张三,李四,王五*@version1.2,2001-03-25*@seeLogIteraotor*@seeBasicLog*@sinceCommonLog1.0*/<...省略了文件注释、包语句、类的注释…>publicclassKeyManagerprivateintkey=0;//key属性记录关键事件ID设置关键事件ID函数功能:呼叫过程,设置(记录)关键事件的ID*@param[key|int]呼叫过程的关键事件ID*@return[void]返回空*/publicvoidsetKey(intkey){this.key=key;}}D./***根据日志类型和时间读取日志。*分配对应日志类型的LogReader,反复器缓冲数,*读取日志记录。查询条件为null或0的表示没限制,*反复器缓冲数为0读不到日志。*@paramlogTypeName日志类型名(在配置文件中定义的)*@paramstartTime查询日志的开始时间*@parambufferNum日志反复器缓冲记录数*@return结果集,日志反复器*@sinceCommonLog1.0*/publicstaticLogIteratorread(StringlogType,DatestartTime,intbufferNum)throwsException{if(null==logType){//如果日志类型没有设置,抛出“日志类型为空”异常thrownewLogTypeException("LogTypeisnull!");}...//programcode}E.publicvoidexample()//注释CodeBlockOne//注释CodeBlockTwo}9下面说法正确的是A没有子类的友好类应该定义成finalB没有被覆盖在友好方法应该定义成finalC不定义在包中没有被用到的友好属性、方法和类D不要定义不会被用到的局部变量、类私有属性、类私有方法和方法参数10下面说法正确的有:A.抛出对于方法内部用throw语句抛出的异常,必须在抛出异常的语句上一行注释标明抛出异常的含义、条件等。B.通过对函数或过程、变量、结构等正确的命名以及合理地组织代码的结构,使代码成为自注释的。对保护方法以清晰准确的函数命名,可增加代码可读性,并减少不必要的注释,甚至可以不注释。C.异常的注释必须说明该异常的含义及什么条件下抛出该异常。D.当代码段较长,特别是多重嵌套时,在程序块的结束行右方加注释标记,以表明某程序块的结束,这样做可以使代码更清晰,更便于阅读。E.调试程序的时候可以方便的使用/*ooo*/注释掉一长段程序。11下面程序片断不符合公司命名规范的有:A.publicclassCar{privatestaticintitemCount=0;publicvoidsetItemCount(intcout)itemCount=cout;}B.publicfinalstaticintDEFAULT-START-KEY=0;C.publicclassLogManager{privateintsize=0;publicbooleanwriteFile(Stringvalue){intsize=0;booleanisRight=false;size=LogUtility.getSize(value);isRight=LogUtility.write(size,value);returnisRight;}}D.protectedabstractbooleangetServiceConfigurationData(intserviceKey);12、下面描述错误的有:A.—个方法不应抛出太多类型的异常,throws/exception子句标明的异常最好不要超过五个。B.运行期异常必须有throws子句标出,不标出或者调用者不捕获该类型异常都会导致编译失败,从而防止程序员本身疏忽。C.抛出非运行期异常的目的是防止异常扩散,导致定位困难。D.在部门内部应该规划好包名的范围,防止产生冲突
Appleapple=array[i];
B.publicinterfaceServiceConst
intMAX_BLACK_SIZE=100;
C.
For(inti=0;i{list.add(FruitFactory.getInstance().createApple());}D.Stringlog=message+“Y”;5.排版时,代码缩进应该采用的方式是(C)ATab缩进B2个空格缩进C4个空格缩进D8个空格缩进6.关于复杂度,下面那句话是错误的:AA继承层次建议不要超过5层B方法行数建议在10-50行C方法参数建议不要超过5个D类的行数不要超过1000行7下列说法错误的是(D)A.尽可能的使用局部变量进行运算。B.不要使用静态集合,其内存占用增长没有边界。C.一个只有abstract方法、finalstatic属性的类应该定义成接口。C.使用while(),sleep()代替wait(),notify()。8下面说法错误的是(D)A.属性名不能与方法名相同。B.方法重载的时候,一定要注意方法名相同。C.方法的参数名不要和类中的方法名相同。D.使用equals()比较两个类是否相同。9下列关于注释说法正确的是CA包注释可有可无,一般大家都是看类注释和方法注释B可以把一个类的类注释改为它的文件注释C类注释应该放在package关键字之后,class或者interface关键字之前D文件注释应该使用javadoc定义的方式注释,保证能够被收集并形成doc文档10关于安全,下面那句话是正确的:DA任何时候都不要使用内部类B任何时候都不要使类可以克隆C任何时候不要使接口可以序列化D为方法、属性和类定义明确的存取控制,并且尽量不要使用友好方法、属性和类11于说法正确的是:DA.使用StringBuffer的时候设置初始容量,推荐设置为1024。B.使用StringBuffer代替StringC.在国际化相关的处理逻辑,不要使用String。D.不要通过名字比较两个对象的类,应该使用instanceof()E.类调用方法的最大规模建议不超过20个。12列关于finalize()的描述错误的有:DA.在finalize。方法中一定要调用super.finalize()方法B.在finalize()方法中的finally中调用super.finalize()方法;C.不要在finalize()方法中删除监听器(Listeners);D.可以在finalize()方法中删除监听器(Listeners);13下列错误使用异常的做法是(D)A.在程序中使用异常处理还是使用错误返回码处理,根据是否有利于程序结构来确定,并且异常和错误码不应该混合使用,推荐使用异常。B.一个方法不应抛出太多类型的异常。throws/exception子句标明的异常最好不要超过三个。C.异常捕获尽量不要直接catch(Exceptionex),应该把异常细分处理。D.程序内抛出的异常本身就可说明异常的类型、抛出条件,可不填写详细的描述信息。捕获异常后用exception.toString()取到详细信息后保存。14、下列说法错误的是:A.段代码各语句之间有实质性关联并且是完成同一件功能的,那么可考虑把此段代码构造成一个新的方法。B.源程序中关系较为紧密的代码应尽可能相邻。C.程序中可同时使用错误码和异常进行处理,推荐使用异常。D.方法参数建议不超过5个。15下面的选项与公司的排版规范不相符的是A.如果语句已足够清晰则括号内侧(即左括号后面和右括号前面)不需要加空格,多重括号间不必加空格,因为在Java语言中括号已是最清晰的标志了。B.DatabaseKeyservicekey=null;key=getServiceKey();currentEventsCount=getCurrentEventsCount();if(currentEventsCount>0){//...programcode}C.if(writeToFile){writeFileThread.interrupt();}D.if((a>=b)&&(c>d)){//programcode}E.在长语句中,如果需要加的空格非常多,那么应该保持整体清晰,而在局部不加空格。给操作符留空格时不要连续留两个以上空格16下面说法或者语句不符合公司编程规范的排版要求的是:A.逗号、分号只在后面加空格;比较操作符,赋值操作符"="、"+=",算术操作符"+"、"%",逻辑操作符"&&"、"&",位域操作符"<<"、"A"等双目操作符的前后加空格;"!"、"〜"、"++"、"--"、"&"(地址运算符)等单目操作符前后不加空格;B.a*=2;C.x=y&z;D.key--;17有关各种注释内容,描述错误的是:A.成员变量注释内容:成员变量的意义、目的、功能,可能被用到的地方。B.公有和保护方法注释内容:列出方法的一句话功能简述、功能详细描述、作者、输入参数、输出参数、返回值、违例等。C.类和接口的注释内容:类的注释主要是一句话功能简述、功能详细描述,可根据需要列出:版本号、生成日期、作者、内容、功能、与其它类的关系等。如果一个类存在Bug,请如实说明这些Bug。D.文件注释内容有:文件名、版权说明、描述信息、生成日期、修改历史。E.包的注释内容:简述本包的作用、详细描述本包的内容、产品模块名称和版本、公司版权。18下面说法正确的是:A.编写代码边注释,修改代码同时修改相应的注释,以保证注释与代码的一致性。不再有用的注释不要删除,使用@deprecated表示此注释无效。B.避免在注释中使用缩写,特别是不常用缩写;但是,注释也是可使用缩写,在使用缩写时或之前,应对缩写进行必要的说明。C.在程序块的结束行下方加注释标记,以表明某程序块的结束。D.注释应考虑程序易读及外观排版的因素,使用的语言若是中、英兼有的,根据公司国际化的趋势,建议多使用英文。三、多选题(每题3分,共36分)1、下面的程序片断不符合编码规范的有:A.privatefinalstaticintTRUNK_BUSY=1;privatefinalstaticintTRUNK_UNKNOWN=-1;publicintwriteToDatabase(){...//programcodeif(state==TRUNK_IDLE){state=TRUNK_BUSY;...//programcodereturn0;else{state=TRUNK_UNKNOWN;return-1;}}B.privatevoidinitializePool(intcount)throwsException{//programcodetry{//programcode}catch(OutOfMemoryErrorex){thrownewError(ex.toString());}}C.if((a|b)&&(a&c))D.rect.length=10;context.phoneNumber=callData.getPhoneNumber();rect.width=5;2、下面描述中符合公司编程规范的说法有:A.不要使用空的for、if、while语句。B.在switch中每个case语句都应该包含break或者return。C.在运算中允许减小数据的精度,在赋值过程要进行强制转型操作。D.switch语句中的case关键字要和后面的常量保持一个空格,switch语句中不要定义case之外的无用标签。E.尽量显式初始化所有的静态属性,但是对于int、char等等非Object属性,都有默认值,可以不进行初始化。3、对包的命名,下面正确的是:Acom.huawei.产品名.模块名称Bcom.huawei.开发组名称.项目名称Ccom.huawei.部门名称.模块名称Dcom.huawei.部门名称.项目名称4、关于String和StringBuffer,下面哪些是正确的A常量字符串使用String,非常量字符串使用StringBufferB使用StringBuffer的时候设置初始容量C尽量使用StringTokenizer代替indexOf()和substring()C尽量不要使用StringBuffer,StringTokenizer类5、下列使用异常的错误的是A.程序发生了致命的错误,抛出一个ERROR!误通知虚拟机。B.程序必须足够健壮,在有可能抛出ERRO错误的地方,将其捕获处理,以免错误扩散C.运行期异常是程序在运行过程中本身考虑不周导致的异常,程序设计之初考虑不周是难免的,设计时应该定义RuntimeException的子类表示这种异常。D.方法内可能抛出的异常必须在方法声明上加throws子句。6、下面的做法符合公司的编程规范要求的有:A.明确方法功能,精确或近似地实现方法设计。一个函数仅完成一件功能,即使简单功能也应该编写方法实现。B.应明确规定对接口方法参数的合法性检查应由接口方法本身负责还是由方法的调用者负责,缺省是由后者负责。C.注释的原则是有助于对程序的阅读理解,如果一个类存在Bug,要如实说明这些Bug。D.父类如果实现了比较合理的toString(),子类可以继承不必再重写toString()。E.数据库操作、IO操作等需要使用结束close()的对象必须在try-catch-finally的finally中close()<7、下列程序片断符合编码规则的有:A.try{//...程序}catch(NullPointExceptionex){Log.doLog(ex.getMessage());}B.publicvoidsubscribe(intid){//programcodeSystem.out.println("Result:"+id+"subscribesucceed")//programcode}C.publicvoidsubscribe(intid){//programcodeLogManager.info("Result:"+id+"subscribeissucceed")}D.try{}catch(ServiceExceptionioe){LogManager.warn(ioe);}8下面哪些符合公司的编程规范的注释要求的有:A.文件注释:/*文件名:LogManager.java描述:WINV200R002WEBSMAP通用日志系统修改人:张三修改时间:2001-02-16修改内容:新增*/B.类注释:/***LogManager类集中控制对日志读写的操作。*全部为静态变量和静态方法,对外提供统一接口。分配对应日志类型的读写器,*读取或写入符合条件的日志纪录。*@author张三,李四,王五*@version1.2,2001-03-25*@seeLogIteraotor*@seeBasicLog*@sinceCommonLog1.0*/<...省略了文件注释、包语句、类的注释…>publicclassKeyManagerprivateintkey=0;//key属性记录关键事件ID设置关键事件ID函数功能:呼叫过程,设置(记录)关键事件的ID*@param[key|int]呼叫过程的关键事件ID*@return[void]返回空*/publicvoidsetKey(intkey){this.key=key;}}D./***根据日志类型和时间读取日志。*分配对应日志类型的LogReader,反复器缓冲数,*读取日志记录。查询条件为null或0的表示没限制,*反复器缓冲数为0读不到日志。*@paramlogTypeName日志类型名(在配置文件中定义的)*@paramstartTime查询日志的开始时间*@parambufferNum日志反复器缓冲记录数*@return结果集,日志反复器*@sinceCommonLog1.0*/publicstaticLogIteratorread(StringlogType,DatestartTime,intbufferNum)throwsException{if(null==logType){//如果日志类型没有设置,抛出“日志类型为空”异常thrownewLogTypeException("LogTypeisnull!");}...//programcode}E.publicvoidexample()//注释CodeBlockOne//注释CodeBlockTwo}9下面说法正确的是A没有子类的友好类应该定义成finalB没有被覆盖在友好方法应该定义成finalC不定义在包中没有被用到的友好属性、方法和类D不要定义不会被用到的局部变量、类私有属性、类私有方法和方法参数10下面说法正确的有:A.抛出对于方法内部用throw语句抛出的异常,必须在抛出异常的语句上一行注释标明抛出异常的含义、条件等。B.通过对函数或过程、变量、结构等正确的命名以及合理地组织代码的结构,使代码成为自注释的。对保护方法以清晰准确的函数命名,可增加代码可读性,并减少不必要的注释,甚至可以不注释。C.异常的注释必须说明该异常的含义及什么条件下抛出该异常。D.当代码段较长,特别是多重嵌套时,在程序块的结束行右方加注释标记,以表明某程序块的结束,这样做可以使代码更清晰,更便于阅读。E.调试程序的时候可以方便的使用/*ooo*/注释掉一长段程序。11下面程序片断不符合公司命名规范的有:A.publicclassCar{privatestaticintitemCount=0;publicvoidsetItemCount(intcout)itemCount=cout;}B.publicfinalstaticintDEFAULT-START-KEY=0;C.publicclassLogManager{privateintsize=0;publicbooleanwriteFile(Stringvalue){intsize=0;booleanisRight=false;size=LogUtility.getSize(value);isRight=LogUtility.write(size,value);returnisRight;}}D.protectedabstractbooleangetServiceConfigurationData(intserviceKey);12、下面描述错误的有:A.—个方法不应抛出太多类型的异常,throws/exception子句标明的异常最好不要超过五个。B.运行期异常必须有throws子句标出,不标出或者调用者不捕获该类型异常都会导致编译失败,从而防止程序员本身疏忽。C.抛出非运行期异常的目的是防止异常扩散,导致定位困难。D.在部门内部应该规划好包名的范围,防止产生冲突
{list.add(FruitFactory.getInstance().createApple());
D.Stringlog=message+“Y”;
5.排版时,代码缩进应该采用的方式是(C)
ATab缩进
B2个空格缩进
C4个空格缩进
D8个空格缩进
6.关于复杂度,下面那句话是错误的:
A
A继承层次建议不要超过5层
B方法行数建议在10-50行
C方法参数建议不要超过5个
D类的行数不要超过1000行
7下列说法错误的是(D)
A.尽可能的使用局部变量进行运算。
B.不要使用静态集合,其内存占用增长没有边界。
C.一个只有abstract方法、finalstatic属性的类应该定义成接口。
C.使用while(),sleep()代替wait(),notify()。
8下面说法错误的是(D)
A.属性名不能与方法名相同。
B.方法重载的时候,一定要注意方法名相同。
C.方法的参数名不要和类中的方法名相同。
D.使用equals()比较两个类是否相同。
9下列关于注释说法正确的是C
A包注释可有可无,一般大家都是看类注释和方法注释
B可以把一个类的类注释改为它的文件注释
C类注释应该放在package关键字之后,class或者interface关键字之前
D文件注释应该使用javadoc定义的方式注释,保证能够被收集并形成doc文档
10关于安全,下面那句话是正确的:
D
A任何时候都不要使用内部类
B任何时候都不要使类可以克隆
C任何时候不要使接口可以序列化
D为方法、属性和类定义明确的存取控制,并且尽量不要使用友好方法、属性和类
11于说法正确的是:
A.使用StringBuffer的时候设置初始容量,推荐设置为1024。
B.使用StringBuffer代替String
C.在国际化相关的处理逻辑,不要使用String。
D.不要通过名字比较两个对象的类,应该使用instanceof()
E.类调用方法的最大规模建议不超过20个。
12列关于finalize()的描述错误的有:
A.在finalize。
方法中一定要调用super.finalize()方法
B.在finalize()方法中的finally中调用super.finalize()方法;
C.不要在finalize()方法中删除监听器(Listeners);
D.可以在finalize()方法中删除监听器(Listeners);
13下列错误使用异常的做法是(D)
A.在程序中使用异常处理还是使用错误返回码处理,根据是否有利于程序结构来确定,并且异常和错误码
不应该混合使用,推荐使用异常。
捕获异常后用
exception.toString()取到详细信息后保存。
14、下列说法错误的是:
A.段代码各语句之间有实质性关联并且是完成同一件功能的,那么可考虑把此段代码构造成一个新的方
法。
15下面的选项与公司的排版规范不相符的是
A.如果语句已足够清晰则括号内侧(即左括号后面和右括号前面)不需要加空格,多重括号间不必加空格,
因为在Java语言中括号已是最清晰的标志了。
B.
DatabaseKeyservicekey=null;
key=getServiceKey();
currentEventsCount=getCurrentEventsCount();
if(currentEventsCount>0)
//...programcode
if(writeToFile)
writeFileThread.interrupt();
D.
if((a>=b)&&(c>d))
//programcode
E.在长语句中,如果需要加的空格非常多,那么应该保持整体清晰,而在局部不加空格。
给操作符留空格时不要连续留两个以上空格
16下面说法或者语句不符合公司编程规范的排版要求的是:
A.逗号、分号只在后面加空格;比较操作符,赋值操作符"="、"+=",算术操作符"+"、"%",逻辑操
作符"&&"、"&",位域操作符"<<"、"A"等双目操作符的前后加空格;"!
"、"〜"、"++"、"--"、"&"(地
址运算符)等单目操作符前后不加空格;
B.a*=2;
C.x=y&z;
D.key--;
17有关各种注释内容,描述错误的是:
A.成员变量注释内容:
成员变量的意义、目的、功能,可能被用到的地方。
B.公有和保护方法注释内容:
列出方法的一句话功能简述、功能详细描述、作者、输入参数、输出参数、返回值、违例等。
C.类和接口的注释内容:
类的注释主要是一句话功能简述、功能详细描述,可根据需要列出:
版本号、生
成日期、作者、内容、功能、与其它类的关系等。
如果一个类存在Bug,请如实说明这些Bug。
D.文件注释内容有:
文件名、版权说明、描述信息、生成日期、修改历史。
E.包的注释内容:
简述本包的作用、详细描述本包的内容、产品模块名称和版本、公司版权。
18下面说法正确的是:
A.编写代码边注释,修改代码同时修改相应的注释,以保证注释与代码的一致性。
不再有用的注释不要删除,使用@deprecated表示此注释无效。
B.避免在注释中使用缩写,特别是不常用缩写;但是,注释也是可使用缩写,在使用缩写时或之前,应对缩写进行必要的说明。
C.在程序块的结束行下方加注释标记,以表明某程序块的结束。
D.注释应考虑程序易读及外观排版的因素,使用的语言若是中、英兼有的,根据公司国际化的趋势,建议多使用英文。
三、多选题(每题3分,共36分)
1、下面的程序片断不符合编码规范的有:
privatefinalstaticintTRUNK_BUSY=1;
privatefinalstaticintTRUNK_UNKNOWN=-1;
publicintwriteToDatabase()
...//programcode
if(state==TRUNK_IDLE)
state=TRUNK_BUSY;
return0;
else
state=TRUNK_UNKNOWN;
return-1;
privatevoidinitializePool(intcount)throwsException
try
catch(OutOfMemoryErrorex)
thrownewError(ex.toString());
C.if((a|b)&&(a&c))
rect.length=10;
context.phoneNumber=callData.getPhoneNumber();
rect.width=5;
2、下面描述中符合公司编程规范的说法有:
A.不要使用空的for、if、while语句。
B.在switch中每个case语句都应该包含break或者return。
C.在运算中允许减小数据的精度,在赋值过程要进行强制转型操作。
D.switch语句中的case关键字要和后面的常量保持一个空格,switch语句中不要定义case之外的
无用标签。
E.尽量显式初始化所有的静态属性,但是对于int、char等等非Object属性,都有默认值,可以不进行
初始化。
3、对包的命名,下面正确的是:
Acom.huawei.产品名.模块名称
Bcom.huawei.开发组名称.项目名称
Ccom.huawei.部门名称.模块名称
Dcom.huawei.部门名称.项目名称
4、关于String和StringBuffer,下面哪些是正确的
A常量字符串使用String,非常量字符串使用StringBuffer
B使用StringBuffer的时候设置初始容量
C尽量使用StringTokenizer代替indexOf()和substring()
C尽量不要使用StringBuffer,StringTokenizer类
5、下列使用异常的错误的是
A.程序发生了致命的错误,抛出一个ERROR!
误通知虚拟机。
B.程序必须足够健壮,在有可能抛出ERRO错误的地方,将其捕获处理,以免错误扩散
C.运行期异常是程序在运行过程中本身考虑不周导致的异常,程序设计之初考虑不周是难免的,设计时应该定义RuntimeException的子类表示这种异常。
D.方法内可能抛出的异常必须在方法声明上加throws子句。
6、下面的做法符合公司的编程规范要求的有:
A.明确方法功能,精确或近似地实现方法设计。
一个函数仅完成一件功能,即使简单功能也应该编写方法实现。
B.应明确规定对接口方法参数的合法性检查应由接口方法本身负责还是由方法的调用者负责,缺省是由后者负责。
C.注释的原则是有助于对程序的阅读理解,如果一个类存在Bug,要如实说明这些Bug。
D.父类如果实现了比较合理的toString(),子类可以继承不必再重写toString()。
E.数据库操作、IO操作等需要使用结束close()的对象必须在try-catch-finally的finally中close()<
7、下列程序片断符合编码规则的有:
//...程序
catch(NullPointExceptionex)
Log.doLog(ex.getMessage());
publicvoidsubscribe(intid)
System.out.println("Result:
"+id+"subscribesucceed")//programcode
C.publicvoidsubscribe(intid)
LogManager.info("Result:
"+id+"subscribeissucceed")
D.try
catch(ServiceExceptionioe)
LogManager.warn(ioe);
8下面哪些符合公司的编程规范的注释要求的有:
A.文件注释:
/*
文件名:
LogManager.java
描述:
WINV200R002WEBSMAP通用日志系统
修改人:
张三
修改时间:
2001-02-16
修改内容:
新增
*/
B.类注释:
/**
*LogManager类集中控制对日志读写的操作。
*全部为静态变量和静态方法,对外提供统一接口。
分配对应日志类型的读写器,
*读取或写入符合条件的日志纪录。
*@author张三,李四,王五
*@version1.2,2001-03-25
*@seeLogIteraotor
*@seeBasicLog
*@sinceCommonLog1.0
<...省略了文件注释、包语句、类的注释…>
publicclassKeyManager
privateintkey=0;//key属性记录关键事件ID
设置关键事件ID函数功能:
呼叫过程,设置(记录)关键事件的ID
*@param[key|int]呼叫过程的关键事件ID
*@return[void]返回空
*/publicvoidsetKey(intkey){
this.key=key;
*根据日志类型和时间读取日志。
*分配对应日志类型的LogReader,反复器缓冲数,
*读取日志记录。
查询条件为null或0的表示没限制,
*反复器缓冲数为0读不到日志。
*@paramlogTypeName日志类型名(在配置文件中定义的)
*@paramstartTime查询日志的开始时间
*@parambufferNum日志反复器缓冲记录数
*@return结果集,日志反复器
publicstaticLogIteratorread(StringlogType,DatestartTime,
intbufferNum)
throwsException
if(null==logType)
//如果日志类型没有设置,抛出“日志类型为空”异常thrownewLogTypeException("LogTypeisnull!
");
E.
publicvoidexample()
//注释
CodeBlockOne
CodeBlockTwo
9下面说法正确的是
A没有子类的友好类应该定义成final
B没有被覆盖在友好方法应该定义成final
C不定义在包中没有被用到的友好属性、方法和类
D不要定义不会被用到的局部变量、类私有属性、类私有方法和方法参数
10下面说法正确的有:
抛出
对于方法内部用throw语句抛出的异常,必须在抛出异常的语句上一行注释标明抛出异常的含义、
条件等。
B.通过对函数或过程、变量、结构等正确的命名以及合理地组织代码的结构,使代码成为自注释的。
对保
护方法以清晰准确的函数命名,可增加代码可读性,并减少不必要的注释,甚至可以不注释。
C.异常的注释必须说明该异常的含义及什么条件下抛出该异常。
D.当代码段较长,特别是多重嵌套时,在程序块的结束行右方加注释标记,以表明某程序块的结束,这样
做可以使代码更清晰,更便于阅读。
E.调试程序的时候可以方便的使用/*ooo*/注释掉一长段程序。
11下面程序片断不符合公司命名规范的有:
publicclassCar
privatestaticintitemCount=0;
publicvoidsetItemCount(intcout)itemCount=cout;
publicfinalstaticintDEFAULT-START-KEY=0;
publicclassLogManager
privateintsize=0;
publicbooleanwriteFile(Stringvalue)
intsize=0;
booleanisRight=false;
size=LogUtility.getSize(value);
isRight=LogUtility.write(size,value);
returnisRight;
D.protectedabstractbooleangetServiceConfigurationData(intserviceKey);
12、下面描述错误的有:
A.—个方法不应抛出太多类型的异常,throws/exception子句标明的异常最好不要超过五个。
B.运行期异常必须有throws子句标出,不标出或者调用者不捕获该类型异常都会导致编译失败,从而防
止程序员本身疏忽。
C.抛出非运行期异常的目的是防止异常扩散,导致定位困难。
D.在部门内部应该规划好包名的范围,防止产生冲突
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1