华为的JAVA面试题
(后记:没有想到华为的面试题就是非同一般,非常多题不是一眼就行看得出来,至少对我这种鸟来说是这样。对我个人来说,看看这种题,可能比看《Think In Java》都还要好,由于这里面有非常多的东西,都是我们平时没有太在意,或者是仅仅是懂一点皮毛而已,通过做一下这种练习,把自己不知道、不熟悉的知识点,利用这个机会好好的巩固一下。这些答案是我自己做的,有一些是从网上来的,有一部是自己做的,而且另一部份没有做完,我不敢保证都对,所以请你在引用的时候,务必通过自己核对一下。当然,我既然可以把这些答案放在这里,那说明我肯定是自己检验了一遍的,也不是那么恐怖的)
QUESTION NO: 1
publicclass Test1 {
publicstaticvoid changeStr(String str){
str="welcome";
}
publicstaticvoid main(String[] args) {
String str="1234";
changeStr(str);
System.out.println(str);
}
}
//输出结果:1234
//这里尽管是一个静态方法,可是里面的变量是一个局部变量,
//所以这里不由于是静态方法,就误觉得里面的变量也是静态变量了
QUESTION NO:2
publicclass Test2 {
staticboolean foo(char c) {
System.out.print(c);
returntrue;
}
publicstaticvoid main(String[] argv) {
int i = 0;
//for(65;88&&(i<2);67)
for (foo(‘A‘); foo(‘B‘) && (i < 2); foo(‘C‘)) {
i++;
foo(‘D‘);
}
}
}
/*
What is the result?
A. ABDCBDCB
B. ABCDABCD
C. Compilation fails.
D. An exception is thrown at runtime.
//输出结果是:ABDCBDCB
分析:FOR循环里面讲究的条件要为真,与你的推断式是什么没有关系
就像这里,尽管是打印的字母,可是却不是false,所以能够运行
第一次进行循环:
foo(‘A‘)打印字母A,(注:这里不是false条件就默觉得true条件)
foo(‘B‘)打印字母B,i=0,比較(i < 2),条件为true,进行循环体,foo(‘D‘)打印D
foo(‘C‘)打印字母C
第二次循环:
foo(‘B‘)打印B,i=1,比較(i < 2)为true,进行循环体,foo(‘D‘)打印D
foo(‘C‘)打印字母C
第三次循环:
foo(‘B‘)打印字母B,i=2,比較(i < 2)为false,退出循环,得结果
*/
QUESTION NO: 3
1. class A {
2. protected int method1(int a, int b) { return 0; }
3. }
Which two are valid in a class that extends class A? (Choose two)
A. public int method1(int a, int b) { return 0; }
B. private int method1(int a, int b) { return 0; }
C. private int method1(int a, long b) { return 0; }
D. public short method1(int a, int b) { return 0; }
E. static protected int method1(int a, int b) { return 0; }
publicclass B extends A{
/**
*@paramargs
*/
//can not reduce the visibility of the inherited method from A
//即不可以使从类A中继续来的方法的可见性减少
//private int method1(int a, int b) { return 0; }
//This static method cannot hide the instance method from A
//静态方法不可以隐藏继承于A的实例
//static protected int method1(int a, int b) { return 0; }
//返回类型与A中的该方法不一致
//public short method1(int a, int b) { return 0; }
/**
*总结:类的继承中,假设要想重载父类的方法,必需要和父类中的返回类型、可见性等等都要操作一致
*否则,程序就会报错。一定遵守子类要遵从于父类的原则
*而我选择的答案竟然是privateintmethod1和staticprotectedint
*我选择第一个的错误理由是:由于原来为保护的,假设我这里设为public,那么就扩展了其原来的可见性
*本来原来就是对包外不可见的,如今变成对包外可见的了,所以就选择的是private
*选择第二个的错误理由是:都是保护的,这里仅仅是变成了静态的而已
*/
//这里是写了一个重载方法,由于參数类型不一致,不会报错
privateint method1(int a, long b) { return 0; }
//可见性可以增大,可是不可以缩小,正确
publicint method1(int a, int b) { return 0; }
publicstaticvoid main(String[] args) {
// TODO Auto-generated method stub
}
}
QUESTION NO: 4
1. public class Outer{
2. public void someOuterMethod() {
3. // Line 3
4. }
5. public class Inner{}
6. public static void main( String[]argv ) {
7. Outer o = new Outer();
8. // Line 8
9. }
10. }
Which instantiates an instance of Inner?
A. new Inner(); // At line 3
B. new Inner(); // At line 8
C. new o.Inner(); // At line 8
D. new Outer.Inner(); // At line 8//new Outer().new Inner()
答案例如以下:
publicclass Outer {
publicvoid someOuterMethod() {
// Line 3
new Inner();//放在这里不出错
}
publicclass Inner {
}
publicstaticvoid main(String[] argv) {
Outer o= new Outer();
// Line 8
//o不可以被解释成为一种类型,出错
//new o.Inner();
/**
*以下两种使用方法,都报以下的错误:
*NoenclosinginstanceoftypeOuterisaccessible.
*Mustqualifytheallocationwithanenclosinginstance
*oftypeOuter(e.g.x.newA()wherexisaninstanceofOuter)
*/
//new Outer.Inner();
//new Inner();
}
}
QUESTION NO: 5
Which method is used by a servlet to place its session ID in a URL that is written to the servlet’s response output stream?
(译:那个方法是servlet用于将其session ID入在一个URL中,该URL写入servlet的响应输出流)
A. The encodeURL method of the HttpServletRequest interface.
B. The encodeURL method of the HttpServletResponse interface.
C. The rewriteURL method of the HttpServletRequest interface.
D. The rewriteURL method of the HttpServletResponse interface.
QUESTION NO: 6
Which two are equivalent? (Choose two)
A. <%= YoshiBean.size%>
B. <%= YoshiBean.getSize()%>
C. <%= YoshiBean.getProperty("size")%>
D. <jsp:getProperty id="YoshiBean" param="size"/>
E. <jsp:getProperty name="YoshiBean" param="size"/>
F. <jsp:getProperty id="YoshiBean" property="size"/>
G. <jsp:getProperty name="YoshiBean" property="size"/>
QUESTION NO: 7
Which of the following statements regarding the lifecycle of a session bean are correct?
1. java.lang.IllegalStateException is thrown if SessionContext.getEJBObject() is invoked when a stateful session bean instance is passivated.
2. SessionContext.getRollbackOnly() does not throw an exception when a session bean with bean-managed transaction demarcation is activated.
3. An exception is not thrown when SessionContext.getUserTransaction() is called in the afterBegin method of a bean with container-managed transactions.
4. JNDI access to java:comp/env is permitted in all the SessionSynchronization methods of a stateful session bean with container-managed transaction demarcation.
5. Accessing resource managers in the SessionSynchronization.afterBegin method of a stateful session bean with bean-managed transaction does not throw an exception.
第二部分:概念题
1. 描写叙述Struts体系结构?相应各个部分的开发工作主要包含哪些?
Struts 是MVC的一种实现,它将 Servlet和 JSP 标记(属于 J2EE 规范)用作实现的一部分。Struts继承了MVC的各项特性,并依据J2EE的特点,做了对应的变化与扩展。Struts的体系结构与工作原理例如以下图2所看到的:
1)模型(Model)
在Struts的体系结构中,模型分为两个部分:系统的内部状态和能够改变状态的操作(事务逻辑)。内部状态通常由一组Actinform Bean表示。依据设计或应用程序复杂度的不同,这些Bean能够是自包括的并具有持续的状态,或仅仅在须要时才获得数据(从某个数据库)。大型应用程序通常在方法内部封装事务逻辑(操作),这些方法能够被拥有状态信息的bean调用。比方购物车bean,它拥实用户购买商品的信息,可能还有checkOut()方法用来检查用户的信用卡,并向仓库发定货信息。小型程序中,操作可能会被内嵌在Action类,它是struts框架中控制器角色的一部分。当逻辑简单时这种方法非常适合。建议用户将事务逻辑(要做什么)与Action类所扮演的角色(决定做什么)分开。
2)视图(View)
视图主要由JSP建立,struts包括扩展自己定义标签库(TagLib),能够简化创建全然国际化用户界面的过程。眼下的标签库包括:Bean Tags、HTML tags、Logic Tags、Nested Tags 以及Template Tags等。
3)控制器(Controller)
在struts中,主要的控制器组件是ActionServlet类中的实例servelt,实际使用的servlet在配置文件里由一组映射(由ActionMapping类进行描写叙述)进行定义。对于业务逻辑的操作则主要由Action、ActionMapping、ActionForward这几个组件协调完毕的,当中Action扮演了真正的业务逻辑的实现者,ActionMapping与ActionForward则指定了不同业务逻辑或流程的执行方向。struts-config.xml 文件配置控制器。
2. XML包含哪些解释技术,差别是什么?
包含:DOM(Document Object Modal)文档对象模型,SAX(Simple API for XML)。DOM是一次性将整个文档读入内存操作,假设是文档比較小,读入内存,能够极大提高操作的速度,但假设文档比較大,那么这个就吃力了。所以此时SAX应用而生,它不是一次性的将整个文档读入内存,这对于处理大型文档就比較就力了
3. JSP有哪些内置对象和动作?它们的作用各自是什么?
JSP共同拥有下面9种基本内置组件:
request 用户端请求,此请求会包括来自GET/POST请求的參数
response 网页传回用户端的回应
pageContext 网页的属性是在这里管理
session 与请求有关的会话期
application servlet 正在运行的内容
out 用来传送回应的输出
config servlet的构架部件
page JSP网页本身
exception 针对错误网页,未捕捉的例外
经常使用的组件:request、response、out、session、application、exception
4、SQL问答题
SELECT * FROM TABLE
和
SELECT * FROM TABLE
WHERE NAME LIKE ‘%%‘ AND ADDR LIKE ‘%%‘
AND (1_ADDR LIKE ‘%%‘ OR 2_ADDR LIKE ‘%%‘
OR 3_ADDR LIKE ‘%%‘ OR 4_ADDR LIKE ‘%%‘ )
的检索结果为何不同?
答:
我做了一下測试,在ACCESS里面,用它的查询,这样会和在MYSQL得到不同的结果,各位最好还是试试,我昨天就是在ACCESS里用SQL查询,得到的结果为空,就是没有记录;而在MYSQL里面,条件为空的记录不显示,其他的都显示。
5、SQL问答题
表结构:
1、 表名:g_cardapply
字段(字段名/类型/长度):
g_applyno varchar 8;//申请单号(keyword)
g_applydate bigint 8;//申请日期
g_state varchar 2;//申请状态
2、 表名:g_cardapplydetail
字段(字段名/类型/长度):
g_applyno varchar 8;//申请单号(keyword)
g_name varchar 30;//申请人姓名
g_idcard varchar 18;//申请人身份证号
g_state varchar 2;//申请状态
当中,两个表的关联字段为申请单号。
题目:
1、 查询身份证号码为440401430103082的申请日期
Select g_cardapply.g_ applydate from g_cardapply, g_cardapplydetail where g_cardapplydetail.g_idcard=’’ and g_cardapply.g_applyno=g_cardapplydetail.g_applyno
2、 查询同一个身份证号码有两条以上记录的身份证号码及记录个数
3、 将身份证号码为440401430103082的记录在两个表中的申请状态均改为07
Update g_cardapply. g_state=’07’, g_cardapplydetail .g_state
4、 删除g_cardapplydetail表中全部姓李的记录
------------------------******測试******-----------------
create database mianshi
use mianshi;
create table g_cardapply(
g_applyno varchar(8),
g_applydate bigint,
g_state varchar(20)
)
go
create table g_cardapplydetail(
g_applyno varchar(8),
g_name varchar(30),
g_idcard varchar(18),
g_state varchar(20)
)
1、select a1.g_applydate from g_cardapply as a1 inner join g_cardapplydetail a2 on
a1.g_applyno=a2.g_applyno where a2.g_idcard="123" ;
2、select g_idcard,count(g_idcard) from g_cardapplydetail
group by g_idcard having count(g_idcard)>=2;
3、update g_cardapply set g_state=603 from g_cardapply as g_d inner join g_cardapplydetail as g_c on
g_d.g_applyno=g_c.g_applyno and g_idcard=‘123‘;更新第一个表的g_state
update g_cardapplydetail set g_state=603 where g_idcard=‘123‘;