还剩11页未读,继续阅读
本资源只提供10页预览,全部文档请下载后查看!喜欢就下载吧,查找使用更方便
文本内容:
一、判断题(每题2分,共28分)
1.为了程序更加简洁,我们应该尽量使用下面的方式来赋值a=b=1;错
2.每个类都需要定义构建器;错
3.使用ObjectStream的方法后,调用release释放对象;错调用reset,释放对象
4.不能用异常来做一般流程处理的方式,不要过多地使用异常,异常的处理效率比条件分支低,而且异常的跳转流程难以预测对
5、没有被覆盖的友好方法和没有子类的友好类应该定义成final对
6、简单的类可以通过名字比较两个对象的类,推荐使用getClass或者instanceof错
7、不要调用Thread类的resumesuspendsleepstop方法错
8、判断方法是否是重载,只关注方法名、参数个数、参数类型,不关注方法返回值;对
9、类注释部分,描述部分说明该类或者接口的功能、作用、使用方法和注意事项,每次修改后增加作者、新版本号和当天的日期,@since表示从那个版本开始就有这个类或者接口,@deprecated表示不建议使用该类或者接口对
10、对于方法内部用throw语句抛出的异常,必须在方法的注释中标明;对于所调用的其他方法所抛出的异常,在注释中要求说明所有的异常;对于非RuntimeException,即throws子句声明会抛出的异常,必须在方法的注释中标明对
11.相对独立的程序块之间、变量说明之后必须加行空行;对
12.任何时候都不要使接口可以序列化;对
13.减小单个方法的复杂度,使用的ifwhileforswith语句要在10个以内;对
14.main方法的定义是publicstaticvoidmainStringargs[];错
二、单选题(每题2分,共36分)1下列错误使用异常的做法是(D)A.在程序中使用异常处理还是使用错误返回码处理,根据是否有利于程序结构来确定,并且异常和错误码不应该混合使用,推荐使用异常B.一个方法不应抛出太多类型的异常throws/exception子句标明的异常最好不要超过三个C.异常捕获尽量不要直接catchExceptionex,应该把异常细分处理D.程序内抛出的异常本身就可说明异常的类型、抛出条件,可不填写详细的描述信息捕获异常后用exception.toString取到详细信息后保存2下列说法错误的是CA.段代码各语句之间有实质性关联并且是完成同一件功能的,那么可考虑把此段代码构造成一个新的方法B.源程序中关系较为紧密的代码应尽可能相邻C.程序中可同时使用错误码和异常进行处理,推荐使用异常D.方法参数建议不超过5个3下面对类、方法、属性的说法不符合编程规范的有CA.不要覆盖父类的私有方法B.类中不要使用非私有的非静态属性C.类定义{类的私有属性定义类的公有属性定义类的保护属性定义类的私有方法定义类的公有方法定义类的保护方法定义}D.类私有方法的最大规模建议为15个4下面的程序片断符合JTest规范的是(B)A.forinti=0;iMAX_INDEX;i++{Appleapple=array[i];}B.publicinterfaceServiceConst{intMAX_BLACK_SIZE=100;}C.Forinti=0;iMAX_INDEX;i++{list.addFruitFactory.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属性的类应该定义成接口D.使用whilesleep代替waitnotify8下面说法错误的是(D)A.属性名不能与方法名相同B.方法重载的时候,一定要注意方法名相同C.方法的参数名不要和类中的方法名相同D.使用equals比较两个类是否相同9下列关于注释说法正确的是CA包注释可有可无,一般大家都是看类注释和方法注释B可以把一个类的类注释改为它的文件注释C类注释应该放在package关键字之后,class或者interface关键字之前D文件注释应该使用javadoc定义的方式注释,保证能够被收集并形成doc文档10关于安全,下面那句话是正确的DA任何时候都不要使用内部类B任何时候都不要使类可以克隆C任何时候不要使接口可以序列化D为方法、属性和类定义明确的存取控制,并且尽量不要使用友好方法、属性和类11于说法正确的是DA.使用StringBuffer的时候设置初始容量,推荐设置为1024B.使用StringBuffer代替StringC.在国际化相关的处理逻辑,不要使用StringD.不要通过名字比较两个对象的类,应该使用instanceofE.类调用方法的最大规模建议不超过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.异常捕获尽量不要直接catchExceptionex,应该把异常细分处理D.程序内抛出的异常本身就可说明异常的类型、抛出条件,可不填写详细的描述信息捕获异常后用exception.toString取到详细信息后保存
14、下列说法错误的是A.段代码各语句之间有实质性关联并且是完成同一件功能的,那么可考虑把此段代码构造成一个新的方法B.源程序中关系较为紧密的代码应尽可能相邻C.程序中可同时使用错误码和异常进行处理,推荐使用异常D.方法参数建议不超过5个15下面的选项与公司的排版规范不相符的是A.如果语句已足够清晰则括号内侧即左括号后面和右括号前面不需要加空格,多重括号间不必加空格,因为在Java语言中括号已是最清晰的标志了B.DatabaseKeyservicekey=null;key=getServiceKey;currentEventsCount=getCurrentEventsCount;ifcurrentEventsCount0{//...programcode}C.ifwriteToFile{writeFileThread.interrupt;}D.if(a=b(cd){//programcode}E.在长语句中,如果需要加的空格非常多,那么应该保持整体清晰,而在局部不加空格给操作符留空格时不要连续留两个以上空格16下面说法或者语句不符合公司编程规范的排版要求的是A.逗号、分号只在后面加空格;比较操作符赋值操作符=、+=,算术操作符+、%,逻辑操作符、,位域操作符、^等双目操作符的前后加空格;!、~、++、--、(地址运算符)等单目操作符前后不加空格;B.a*=2;C.x=yz;D.key--;17有关各种注释内容,描述错误的是A.成员变量注释内容成员变量的意义、目的、功能,可能被用到的地方B.公有和保护方法注释内容列出方法的一句话功能简述、功能详细描述、作者、输入参数、输出参数、返回值、违例等C.类和接口的注释内容类的注释主要是一句话功能简述、功能详细描述,可根据需要列出版本号、生成日期、作者、内容、功能、与其它类的关系等如果一个类存在Bug,请如实说明这些BugD.文件注释内容有文件名、版权说明、描述信息、生成日期、修改历史E.包的注释内容简述本包的作用、详细描述本包的内容、产品模块名称和版本、公司版权18下面说法正确的是A.编写代码边注释,修改代码同时修改相应的注释,以保证注释与代码的一致性不再有用的注释不要删除,使用@deprecated表示此注释无效B.避免在注释中使用缩写,特别是不常用缩写;但是,注释也是可使用缩写,在使用缩写时或之前,应对缩写进行必要的说明C.在程序块的结束行下方加注释标记,以表明某程序块的结束D.注释应考虑程序易读及外观排版的因素,使用的语言若是中、英兼有的,根据公司国际化的趋势,建议多使用英文
三、多选题(每题3分,共36分)
1、下面的程序片断不符合编码规范的有A.privatefinalstaticintTRUNK_BUSY=1;privatefinalstaticintTRUNK_UNKNOWN=-1;publicintwriteToDatabase{...//programcodeifstate==TRUNK_IDLE{state=TRUNK_BUSY;...//programcodereturn0;}else{state=TRUNK_UNKNOWN;return-1;}}B.privatevoidinitializePoolintcountthrowsException{//programcodetry{//programcode}catchOutOfMemoryErrorex{thrownewErrorex.toString;}}C.ifa|bacD.rect.length=10;context.phoneNumber=callData.getPhoneNumber;rect.width=5;
2、下面描述中符合公司编程规范的说法有A.不要使用空的for、if、while语句B.在switch中每个case语句都应该包含break或者returnC.在运算中允许减小数据的精度,在赋值过程要进行强制转型操作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和substringC尽量不要使用StringBufferStringTokenizer类
5、下列使用异常的错误的是A.程序发生了致命的错误,抛出一个ERROR错误通知虚拟机B.程序必须足够健壮,在有可能抛出ERROR错误的地方,将其捕获处理,以免错误扩散C.运行期异常是程序在运行过程中本身考虑不周导致的异常,程序设计之初考虑不周是难免的,设计时应该定义RuntimeException的子类表示这种异常D.方法内可能抛出的异常必须在方法声明上加throws子句
6、下面的做法符合公司的编程规范要求的有A.明确方法功能,精确或近似地实现方法设计一个函数仅完成一件功能,即使简单功能也应该编写方法实现B.应明确规定对接口方法参数的合法性检查应由接口方法本身负责还是由方法的调用者负责,缺省是由后者负责C.注释的原则是有助于对程序的阅读理解,如果一个类存在Bug,要如实说明这些BugD.父类如果实现了比较合理的toString,子类可以继承不必再重写toStringE.数据库操作、IO操作等需要使用结束close的对象必须在try-catch-finally的finally中close
7、下列程序片断符合编码规则的有A.try{//...程序}catchNullPointExceptionex{Log.doLogex.getMessage;}B.publicvoidsubscribeintid{//programcodeSystem.out.printlnResult+id+subscribesucceed//programcode……}C.publicvoidsubscribeintid{//programcodeLogManager.infoResult+id+subscribeissucceed}D.try{//.......}catchServiceExceptionioe{LogManager.warnioe;}8下面哪些符合公司的编程规范的注释要求的有A.文件注释/**文件名LogManager.java*描述WINV200R002WEBSMAP通用日志系统*修改人张三*修改时间2001-02-16*修改内容新增*/B.类注释/***LogManager类集中控制对日志读写的操作*全部为静态变量和静态方法,对外提供统一接口分配对应日志类型的读写器,*读取或写入符合条件的日志纪录*@author张三,李四,王五*@version
1.22001-03-25*@seeLogIteraotor*@seeBasicLog*@sinceCommonLog
1.0*/C....省略了文件注释、包语句、类的注释…publicclassKeyManager{privateintkey=0;//key属性记录关键事件ID/***设置关键事件ID*函数功能呼叫过程,设置(记录)关键事件的ID*@param[key|int]呼叫过程的关键事件ID*@return[void]返回空*/publicvoidsetKeyintkey{this.key=key;}}D./***根据日志类型和时间读取日志*分配对应日志类型的LogReader,反复器缓冲数,*读取日志记录查询条件为null或0的表示没限制,*反复器缓冲数为0读不到日志*@paramlogTypeName日志类型名(在配置文件中定义的)*@paramstartTime查询日志的开始时间*@parambufferNum日志反复器缓冲记录数*@return结果集,日志反复器*@sinceCommonLog
1.0*/publicstaticLogIteratorreadStringlogTypeDatestartTimeintbufferNumthrowsException{ifnull==logType{//如果日志类型没有设置,抛出“日志类型为空”异常thrownewLogTypeExceptionLogTypeisnull!;}...//programcode}E.publicvoidexample{//注释CodeBlockOne//注释CodeBlockTwo}9下面说法正确的是A没有子类的友好类应该定义成finalB没有被覆盖在友好方法应该定义成finalC不定义在包中没有被用到的友好属性、方法和类D不要定义不会被用到的局部变量、类私有属性、类私有方法和方法参数10下面说法正确的有A.对于方法内部用throw语句抛出的异常,必须在抛出异常的语句上一行注释标明抛出异常的含义、抛出条件等B.通过对函数或过程、变量、结构等正确的命名以及合理地组织代码的结构,使代码成为自注释的对保护方法以清晰准确的函数命名,可增加代码可读性,并减少不必要的注释,甚至可以不注释C.异常的注释必须说明该异常的含义及什么条件下抛出该异常D.当代码段较长,特别是多重嵌套时,在程序块的结束行右方加注释标记,以表明某程序块的结束,这样做可以使代码更清晰,更便于阅读E.调试程序的时候可以方便的使用/**/注释掉一长段程序11下面程序片断不符合公司命名规范的有A.publicclassCar{privatestaticintitemCount=0;publicvoidsetItemCountintcout{itemCount=cout;}}B.publicfinalstaticintDEFAULT-START-KEY=0;C.publicclassLogManager{privateintsize=0;publicbooleanwriteFileStringvalue{intsize=0;booleanisRight=false;size=LogUtility.getSizevalue;isRight=LogUtility.writesizevalue;returnisRight;}}D.protectedabstractbooleangetServiceConfigurationDataintserviceKey;
12、下面描述错误的有A.一个方法不应抛出太多类型的异常,throws/exception子句标明的异常最好不要超过五个B.运行期异常必须有throws子句标出,不标出或者调用者不捕获该类型异常都会导致编译失败,从而防止程序员本身疏忽C.抛出非运行期异常的目的是防止异常扩散,导致定位困难D.在部门内部应该规划好包名的范围,防止产生冲突。