Java经典面试题大全 带答案.doc

上传人:豆**** 文档编号:29963997 上传时间:2022-08-02 格式:DOC 页数:14 大小:25.50KB
返回 下载 相关 举报
Java经典面试题大全 带答案.doc_第1页
第1页 / 共14页
Java经典面试题大全 带答案.doc_第2页
第2页 / 共14页
点击查看更多>>
资源描述

《Java经典面试题大全 带答案.doc》由会员分享,可在线阅读,更多相关《Java经典面试题大全 带答案.doc(14页珍藏版)》请在得力文库 - 分享文档赚钱的网站上搜索。

1、Java经典面试题 带答案一、单项选择题1Java是从()语言改进重新设计。AAdaBC+CPasacalDBASIC答案:B2下列语句哪一个正确()A Java程序经编译后会产生machine codeBJava程序经编译后会产生byte codeCJava程序经编译后会产生DLLD以上都不正确答案:B3下列说法正确的有()Aclass中的constructor不可省略B constructor必须与class同名,但方法不能与class同名Cconstructor在一个对象被new时执行D一个class只能定义一个constructor答案:C4提供Java存取数据库能力的包是()Ajav

2、a.sqlBjava.awtCjava.langDjava.swing答案:A5下列运算符合法的是()A&BCifD:=答案:A6执行如下程序代码a=0;c=0;do-c;a=a-1;while(a0);后,C的值是()A0B1C-1D死循环答案:C7下列哪一种叙述是正确的()Aabstract修饰符可修饰字段、方法和类B抽象方法的body部分必须用一对大括号包住C声明抽象方法,大括号可有可无D声明抽象方法不可写出大括号答案:D8下列语句正确的是()A形式参数可被视为localvariableB形式参数可被字段修饰符修饰C形式参数为方法被调用时,真正被传递的参数D形式参数不可以是对象答案:A9

3、下列哪种说法是正确的()A实例方法可直接调用超类的实例方法B实例方法可直接调用超类的类方法C实例方法可直接调用其他类的实例方法D实例方法可直接调用本类的类方法答案:D二、多项选择题1Java程序的种类有()A类(Class)BAppletCApplicationDServlet2下列说法正确的有()A环境变量可在编译sourcecode时指定B在编译程序时,所能指定的环境变量不包括class pathCjavac一次可同时编译数个Java源文件Djavac.exe能指定编译结果要置于哪个目录(directory)答案:BCD3下列标识符不合法的有()AnewB$UsdollarsC1234Dc

4、ar.taxi答案:ACD4下列说法错误的有()A数组是一种对象B数组属于一种原生类Cintnumber=31,23,33,43,35,63D数组的大小可以任意改变答案:BCD5不能用来修饰interface的有()AprivateBpublicCprotectedDstatic答案:ACD6下列正确的有()A call byvalue不会改变实际参数的数值B call by reference能改变实际参数的参考地址C call byreference不能改变实际参数的参考地址D call byreference能改变实际参数的内容答案:ACD7下列说法错误的有()A在类方法中可用this来

5、调用本类的类方法B在类方法中调用本类的类方法时可直接调用C在类方法中只能调用本类中的类方法D在类方法中绝对不能调用实例方法答案:ACD8下列说法错误的有()AJava面向对象语言容许单独的过程与函数存在B Java面向对象语言容许单独的方法存在CJava语言中的方法属于类中的成员(member)DJava语言中的方法必定隶属于某一类(对象),调用方法与过程或函数相同答案:ABC9下列说法错误的有()A能被java.exe成功运行的javaclass文件必须有main()方法B J2SDK就是Java APICAppletviewer.exe可利用jar选项运行.jar文件D能被Appletvi

6、ewer成功运行的javaclass文件必须有main()方法答案:BCD三、判断题1Java程序中的起始类名称必须与存放该类的文件名相同。()答案:正确2Unicode是用16位来表示一个字的。()答案:正确3原生类中的数据类型均可任意转换。()答案:错误1.分别写出BOOL,int,float,指针类型的变量a 与“零”的比较语句。答案:BOOL : if ( !a ) orif(a)int : if ( a = 0)float : const EXPRESSION EXP = 0.000001if ( a -EXP)pointer : if ( a !=NULL) or if(a = N

7、ULL)2.请说出const与#define 相比,有何优点?答案:1) const常量有数据类型,而宏常量没有数据类型。编译器可以对前者进行类型安全检查。而对后者只进行字符替换,没有类型安全检查,并且在字符替换可能会产生意料不到的错误。2) 有些集成化的调试工具可以对const 常量进行调试,但是不能对宏常量进行调试。3.简述数组与指针的区别?数组要么在静态存储区被创建(如全局数组),要么在栈上被创建。指针可以随时指向任意类型的内存块。(1)修改内容上的差别char a= “hello”;a0 = X;char *p = “world”; / 注意p 指向常量字符串p0 = X;/ 编译器不

8、能发现该错误,运行时错误(2) 用运算符sizeof 可以计算出数组的容量(字节数)。sizeof(p),p为指针得到的是一个指针变量的字节数,而不是p 所指的内存容量。C+/C语言没有办法知道指针所指的内存容量,除非在申请内存时记住它。注意当数组作为函数的参数进行传递时,该数组自动退化为同类型的指针。char a =hello world;char *p = a;cout sizeof(a) endl; / 12字节cout sizeof(p) endl; / 4 字节计算数组和指针的内存容量voidFunc(char a100)cout sizeof(a) endl; / 4 字节而不是1

9、00字节4.类成员函数的重载、覆盖和隐藏区别?答案:a.成员函数被重载的特征:(1)相同的范围(在同一个类中);(2)函数名字相同;(3)参数不同;(4)virtual 关键字可有可无。b.覆盖是指派生类函数覆盖基类函数,特征是:(1)不同的范围(分别位于派生类与基类);(2)函数名字相同;(3)参数相同;(4)基类函数必须有virtual 关键字。c.“隐藏”是指派生类的函数屏蔽了与其同名的基类函数,规则如下:(1)如果派生类的函数与基类的函数同名,但是参数不同。此时,不论有无virtual关键字,基类的函数将被隐藏(注意别与重载混淆)。(2)如果派生类的函数与基类的函数同名,并且参数也相同

10、,但是基类函数没有virtual 关键字。此时,基类的函数被隐藏(注意别与覆盖混淆)5. There are two int variables: a and b, dont use “if”, “? :”, “switch”orother judgement statements, find out the biggest one of the two numbers.答案:( ( a + b ) + abs( a - b ) ) / 26. 如何打印出当前源文件的文件名以及源文件的当前行号?答案:cout _FILE_ ;cout_LINE_ ;_FILE_和_LINE_是系统预定义宏,这

11、种宏并不是在某个文件中定义的,而是由编译器定义的。7. main主函数执行完毕后,是否可能会再执行一段代码,给出说明?答案:可以,可以用_onexit 注册一个函数,它会在main 之后执行intfn1(void), fn2(void), fn3(void), fn4 (void);void main( void )String str(zhanglin);_onexit( fn1 );_onexit( fn2 );_onexit(fn3 );_onexit( fn4 );printf( This is executed first.n );int fn1()printf( next.n );

12、return 0;int fn2()printf( executed );return 0;int fn3()printf( is );return 0;int fn4()printf( This );return 0;The _onexit function is passed the address of afunction (func) to be called when the program terminates normally. Successivecalls to _onexit create a register of functions that are executed

13、in LIFO(last-in-first-out) order. The functions passed to _onexit cannot takeparameters.8. 如何判断一段程序是由C 编译程序还是由C+编译程序编译的?答案:#ifdef _cpluspluscoutc+;#elsecoutc;#endif9.文件中有一组整数,要求排序后输出到另一个文件中答案:i ncludei ncludeusing namespace std;void Order(vector& data)/bubble sortint count = data.size() ;int tag = f

14、alse ; /设置是否需要继续冒泡的标志位for ( int i = 0 ; i count ; i+)for ( int j =0 ; j dataj+1)tag = true ;int temp = dataj ;dataj = dataj+1 ;dataj+1 = temp ;if ( !tag )break ;void main( void )vectordata;ifstreamin(c:data.txt);if ( !in)couttemp;data.push_back(temp);in.close(); /关闭输入文件流Order(data);ofstream out(c:re

15、sult.txt);if ( !out)coutfileerror!;exit(1);for ( i = 0 ; i data.size() ; i+)outDATAInext = NULL )returnhead;Node *p1 = head ;Node *p2 = p1-next ;Node *p3 =p2-next ;p1-next = NULL ;while ( p3 != NULL )p2-next = p1 ;p1 = p2 ;p2 = p3 ;p3 = p3-next ;p2-next = p1 ;head = p2 ;return head ;2)已知两个链表head1 和h

16、ead2 各自有序,请把它们合并成一个链表依然有序。(保留所有结点,即便大小相同)Node *Merge(Node *head1 , Node *head2)if ( head1 = NULL)return head2;if ( head2 = NULL)return head1 ;Node *head = NULL ;Node*p1 = NULL;Node *p2 = NULL;if ( head1-data data )head = head1 ;p1 = head1-next;p2 = head2 ;elsehead = head2 ;p2 = head2-next ;p1 = head

17、1 ;Node *pcurrent = head ;while ( p1 != NULL & p2 != NULL)if ( p1-data data )pcurrent-next = p1;pcurrent = p1 ;p1 = p1-next ;elsepcurrent-next = p2 ;pcurrent = p2 ;p2 = p2-next ;if ( p1 != NULL )pcurrent-next = p1 ;if ( p2 != NULL )pcurrent-next = p2 ;return head ;(3)已知两个链表head1 和head2各自有序,请把它们合并成一个

18、链表依然有序,这次要求用递归方法进行。 (Autodesk)答案:Node *MergeRecursive(Node *head1 , Node *head2)if ( head1 = NULL )return head2 ;if ( head2 = NULL)return head1 ;Node *head =NULL ;if ( head1-data data )head = head1 ;head-next = MergeRecursive(head1-next,head2);elsehead = head2 ;head-next = MergeRecursive(head1,head2-next);return head ;14 = - = - = ) - * - ( = * - ) - * ( * (行方 用次 序依个成们请自各 和 链两 ; = -两 个 = ;和 - 序! 请 并 成 = 表 - ; = ; - - - = ; - ( * ; = ( ) = ( ) * ( * )小便结留。然

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育专区 > 高考资料

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知得利文库网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号-8 |  经营许可证:黑B2-20190332号 |   黑公网安备:91230400333293403D

© 2020-2023 www.deliwenku.com 得利文库. All Rights Reserved 黑龙江转换宝科技有限公司 

黑龙江省互联网违法和不良信息举报
举报电话:0468-3380021 邮箱:hgswwxb@163.com