1、执行下面的语句后,变量i的值是(编译通不过)
byte i = 127;
i = i+2;
2、表达式(short)10/10.2*2;的数据类型是(double)
3、下面的代码运行结果为(NaN)
public class Test01 {
public static void main(String[] args) {
try {
double x = 64.0;
double y = 0.0;
System.out.println(x % y);
} catch (Exception e) {
System.out.println("Exception");
}
}
}
4、当一个类的所有构造器均为私有的,以下哪个描述是正确的? (C)
A.不能被其他类实例化
B.不能被其他类继承
C.既不能被其他类实例化,也不能被其他类继承
D.该类必须被final 修饰
5、针对默认的无参构造器描述的正确的是(均是public构造器)
6、dom与sax
SAX (Simple API for XML) 和 DOM (Document Object Model) 是当前两个主要的XML API,几乎所有商用的xml 解析器都同时实现了这两个接口
**dom:**DOM模式解析XML,是把整个XML文档当成一个对象来处理,会先把整个文档读入到内存里。是基于树的结构,通常需要加载整文档和构造DOM树,然后才能开始工作。
解析xml有四种方法:DOM,SAX,DOM4j,JDOM.
7、只有满足连接条件的记录才包含在查询结果中,这种连接为内连接
8、cascade(级联)的属性取值有:
- none:忽略其他关联的对象,默认值。
- save-update:当session通过save(),update(),saveOrUpdate()方法来保存或更新对象时,级联保存所有关联的新建的临时对象,并且级联更新所有关联的游离对象。
- persist:当session通过persist()方法来保存当前对象时,会级联保存所有关联的新建的临时对象。
- merge:通过Session的merge()方法来保存当前对象时,会级联融合所有关联的游离对象。
- delete:通过delete()删除当前对象时,会级联删除所有关联的对象。
- lock:通过lock()把当前游离对象加入session缓存时,会把所有的游离对象也加入Session缓存中。
- replicate:通过replicate()复制当前对象时,会级联复制所有关联的对象。
- evict:通过evict()清除session缓存中对象时,会级联清除所有关联的对象。
- refresh:通过refresh()刷新当前对象时,会级联刷新所有关联的对象。(刷新是指同步更新session缓存中数据)
- all:save-update(),persist(),merge(),delete(),lock(),replicate(),evict()及refresh()的行为。
- delete-orphan,删除所有和当前对象时,解除关联行为的对象。
- all-delete-orphan; 通过delete()删除当前对象时,会级联删除所有关联的对象。
9、下面的代码运行结果为:
import java.util.Collections;
import java.util.HashSet;
import java.util.Set;
public class Test01 {
static boolean foo(char c){
System.out.print(c);
return true;
}
public static void main(String[] args) {
int i = 0;
for (foo('A');foo('B')&&(i<2);foo('C')) {
i++;
foo('D');
}
}
}
ABDCBDCB
10、下面的执行结果为:
public class Test01 {
public static void stringReplace(String text){
text = text.replace('j', 'i');
}
public static void bufferReplace(StringBuffer text){
text.append("C");
text = new StringBuffer("Hello");
text.append("world");
}
public static void main(String[] args) {
String textString = new String("java");
StringBuffer sb = new StringBuffer("java");
stringReplace(textString);
bufferReplace(sb);
System.out.println(textString+sb);
}
}
javajavaC
11、给出以下代码,说法正确的是( )。
public XXXX extendssomething1,something2
A.如果XXXX是一个接口,something1和something2取消掉,则代码段合法
B.如果XXXX是一个类,something1和something2均是接口,则代码段合法
C.如果XXXX、something1和something2均是接口,则代码段合法
D.因为Java语言不支持多重继承,所以代码不合法
解析:接口可以通过extends继承多个基础接口,构建一个新的接口选择C
12输出结果为:
public class Test01 {
public static int fun(){
int result = 5;
try {
result = result/0;
return result;
} catch (Exception e) {
System.out.println("Exception");
result = -1;
return result;
}finally{
result= 10;
System.out.println("finally");
}
}
public static void main(String[] args) {
int x = fun();
System.out.println(x);
}
}
Exception
finally
-1
13、SQL,在SELECT语句中,( group by)不能包含子查询。
14、CSS 设置外边距的最简单的方法就是使用 margin 属性,padding 简写属性在一个声明中设置所有内边距属性
15、在JDBC中,如果Connection类的方法setAutoCommit(boolean autoCommit)赋给值为false,那么就可以手动提交(调用Connection类的commit()方法)。如果为true那么就是自动提交
16、如果局部变量的名字与成员变量的名字相同,则成员变量被隐藏,这是如果想在该方法内使用成员变量,必须使用this关键字
17、表单重复提交问题解决(重要):简述jsp MVC模式下重复提交问题产生的原因和解决办法
- 常见重复提交情景
- a>点击提交按钮两次。
- b>点击刷新按钮。
- c>使用浏览器后退按钮重复之前的操作,导致重复提交表单。
- d>使用浏览器历史记录重复提交表单。
- e>浏览器重复的HTTP请求。
解决方案:(参考于http://www.jb51.net/article/43171.htm)
- 禁掉提交按钮。表单提交后disabled现在的按钮或者取消该按钮的点击事件或者默认事件。
- Post/Redirect/Get模式。在提交后执行页面重定向,这就是所谓的Post-Redirect-Get (PRG)模式。简言之,当用户提交了表单后,你去执行一个客户端的重定向,转到提交成功信息页面。这能避免用户按F5导致的重复提交,而其也不会出现浏览器表单重复提交的警告,也能消除按浏览器前进和后退按导致的同样问题。
- 在session中存放一个特殊标志token
- 在数据库里添加约束。在数据库里添加唯一约束或创建唯一索引,防止出现重复数据。这是最有效的防止重复提交数据的方法。
18、forward与redirect的区别(参考与http://zhulin902.iteye.com/blog/939049)
- 从地址栏显示来说
forward是服务器请求资源,服务器直接访问目标地址的URL,把那个URL的响应内容读取过来,然后把这些内容再发给浏览器.浏览器根本不知道服务器发送的内容从哪里来的,所以它的地址栏还是原来的地址.
redirect是服务端根据逻辑,发送一个状态码,告诉浏览器重新去请求那个地址.所以地址栏显示的是新的URL.
- 从数据共享来说
forward:转发页面和转发到的页面可以共享request里面的数据.
redirect:不能共享数据.
- 从运用地方来说
forward:一般用于用户登陆的时候,根据角色转发到相应的模块.
redirect:一般用于用户注销登陆时返回主页面和跳转到其它的网站等.
- 从效率来说
forward:高.
redirect:低.
- 本质区别
- 转发是服务器行为,重定向是客户端行为
- 重定向,其实是两次request
现实中的例子:
假设你去办理某个执照,
重定向:你先去了A局,A局的人说:“这个事情不归我们管,去B局”,然后,你就从A退了出来,自己乘车去了B局。
转发:你先去了A局,A局看了以后,知道这个事情其实应该B局来管,但是他没有把你退回来,而是让你坐一会儿,自己到后面办公室联系了B的人,让他们办好后,送了过来。
19、hibernate中的ID生成器(参考自http://www.cnblogs.com/programmer-wind/archive/2011/09/18/2919580.html)
- identity:用于MySql数据库。特点:递增
< id name="id" column="id">
< generator class="identity"/>
< /id>
注:对于MySql数据库使用递增序列时需要在建表时对主键指定为auto_increment属性。
- sequence:用于Oracle数据库
< id name="id" column="id">
< generator class="sequence">
< param name="sequence">序列名< /param>
< /generator>
< /id>
- native:跨数据库时使用,由底层方言产生。
Default.sequence为hibernate_sequence
< id name="id" column="id">
< generator class="native"/>
< /id>
注:使用native时Hibernate默认会去查找Oracle中的hibernate_sequence序列。
如果Oracle中没有该序列,连Oracle数据库时会报错。
- hilo:通过高低位合成id,先建表hi_value,再建列next_value。必须要有初始值。
< id name="id" column="id">
< generator class="hilo">
< param name="table">high_val< /param>
< param name="column">nextval< /param>
< param name="max_lo">5< /param>
< /generator>
< /id>
- sequencehilo:同过高低位合成id,建一个sequence序列,不用建表。
< id name="id" column="id">
< generator class="hilo">
< param name="sequence">high_val_seq< /param>
< param name="max_lo">5< /param>
< /generator>
< /id>
- assigned:用户自定义id;
< id name="id" column="id">
< generator class="assigned"/>
< /id>
- foreign:用于一对一关系共享主健时,两id值一样。
本文讲解Hibernate中hbm的generator子元素的一些内置生成器的快捷名字。Generator子元素是一个非常简单的接口;某些应用程序可以选择提供他们自己特定的实现。IDCard与Student形成一对一关联,IDCard端的设置映射配置如下:
<class name="IDCard">
<id name="id" column="Card_id">
<generator class="foreign">
<param name="property">student</param>
</generator>
</id>
<property name="IDNo" unique="true"/>
<property name="nationality"/>
<property name="address"/>
<one-to-one name="student" class="Student" constrained="true"/>
</class>
解释:
(1)
指定id生成方式, (之前我们用的id生成方式是native,是让底层数据库自动生成id,目前我的应征环境下,native从1开始,递增生成id)。在这里,我们要用外键来生成主键,所以指定为foreign,也就是去共享关联对象的主键。
(2)student
指定主键来源,这里的student是关联名称。
(3)
指定与Student形成一对一关联,
(4)constrained=”true”
该选项最关键的是影响save和delete的先后顺序
没有设定时:总是先操作关联表,后操作本表;
设定以后:添加时先关联表,后本表;删除时先本表,再操作关联表。
在*.hbm.xml必须声明的< generator>子元素是一个Java类的名字,用来为该持久化类的实例生成唯一的标识。
< generator class=”sequence”/>
这是一个非常简单的接口;某些应用程序可以选择提供他们自己特定的实现。当然,Hibernate提供了很多内置的实现。下面是Generator子元素的一些内置生成器的快捷名字:
increment(递增)
用于为long, short或者int类型生成唯一标识。只有在没有其他进程往同一张表中插入数据时才能使用。在集群下不要使用。
identity
对DB2,MySQL, MS SQL Server, Sybase和HypersonicSQL的内置标识字段提供支持。返回的标识符是long, short 或者int类型的。
sequence (序列)
在DB2,PostgreSQL, Oracle, SAP DB, McKoi中使用序列(sequence),而在Interbase中使用生成器(generator)。返回的标识符是long, short或者 int类型的。
hilo (高低位)
使用一个高/低位算法来高效的生成long, short或者 int类型的标识符。给定一个表和字段(默认分别是是hibernate_unique_key 和next_hi)作为高位值得来源。高/低位算法生成的标识符只在一个特定的数据库中是唯一的。在使用JTA获得的连接或者用户自行提供的连接中,不要使用这种生成器。
seqhilo(使用序列的高低位)
使用一个高/低位算法来高效的生成long, short或者 int类型的标识符,给定一个数据库序列(sequence)的名字。
uuid.hex
用一个128-bit的UUID算法生成字符串类型的标识符。在一个网络中唯一(使用了IP地址)。UUID被编码为一个32位16进制数字的字符串。
uuid.string
使用同样的UUID算法。UUID被编码为一个16个字符长的任意ASCII字符组成的字符串。不能使用在PostgreSQL数据库中
native(本地)
根据底层数据库的能力选择identity, sequence 或者hilo中的一个。
assigned(程序设置)
让应用程序在save()之前为对象分配一个标示符。
foreign(外部引用)
使用另外一个相关联的对象的标识符。和< one-to-one>联合一起使用。
Generator子元素的用法:
< class name="onlyfun.caterpillar.User" table="USER">
< id name="id" type="string" unsaved-value="null">
< column name="USER_ID"/>
< generator class="uuid.hex"/>
< /id>