面试题总结(一)

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>  
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值