Java实习生面试题分享 (4)

short s1 = 1; s1 = s1 + 1; s1+1运算结果是int型,需要强制转换类型)   short s1 = 1; s1 += 1;(可以正确编译)

22.floatfloat f=3.4是否正确?

不正确。精度不准确,应该用强制类型转换,如下所示:float f=(float)3.4 float f = 3.4f

java里面,没小数点的默认是int,有小数点的默认是 double;
23.ArrayListVector的区别,HashMapHashtable的区别。

ArrayListVector都是使用数组方式存储数据,此数组元素数大于实际存储的数据以便增加和插入元素,它们都允许直接按序号索引元素,但是插入元素要涉及数组元素移动等内存操作,所以索引数据快而插入数据慢,Vector由于使用了synchronized方法(线程安全),通常性能上较ArrayList差。

HashMapHashtable的轻量级实现(非线程安全的实现),他们都完成了Map接口,主要区别在于HashMap允许空(null)键值(key,由于非线程安全,效率上可能高于Hashtable

HashMap允许将null作为一个entrykey或者value,而Hashtable不允许。

HashMapHashtablecontains方法去掉了,改成containsvaluecontainsKey。因为contains方法容易让人引起误解。 Hashtable继承自Dictionary类,而HashMapJava1.2引进的Map interface的一个实现。

最大的不同是,Hashtable的方法是Synchronize的,而HashMap不是,在多个线程访问Hashtable时,不需要自己为它的方法实现同步,而HashMap 就必须为之提供外同步。

24.ErrorException有什么区别?

error 表示恢复不是不可能但很困难的情况下的一种严重问题。比如说内存溢出。不可能指望程序能处理这样的情况。

exception 表示一种设计或实现问题。也就是说,它表示如果程序运行正常,从不会发生的情况。

25.statement preparestatement区别

1)创建时的区别:

Statement stm=con.createStatement();

PreparedStatement pstm=con.prepareStatement(sql);

执行的时候:

stm.execute(sql);

pstm.execute();

2pstm一旦绑定了SQL,pstm就不能执行其他的Sql,即只能执行一条SQL命令。

stm可以执行多条SQL命令。

3)对于执行同构的sql(只有值不同,其他结构都相同),pstm的执行效率比较的高,对于异构的SQL语句,Statement的执行效率要高。

4)当需要外部变量的时候,pstm的执行效率更高.

26.写一个数据库连接类,包括查询及结果存储。

import java.sql.*;     //需要加入的包

//类的定义

class DBConnect {

private String con1 = "sun.jdbc.odbc.JdbcOdbcDriver"; //连接SQL所需要的字符串

private String url = "jdbc:odbc:test";

private String user = "sa", password = ""; //这里请根据您的数据库用户和密码自行修改

Connection con;           //用于连接数据库用的

PreparedStatement ps;     //其实用Statement也行,PreparedStatement集成了Statement.

ResultSet rs;             //一个集合,可以用于执行SQL命令

//构造函数

DBConnect() {

try {

Class.forName(con1); //Class.forName()用于将一些类加载到JVM

this.Connect();   //函数调用

try {

this.execute();

} catch (SQLException ex) {

System.out.println(ex.toString());

}

} catch (ClassNotFoundException ce) {

System.out.println(ce);

}

}

public void Connect() {

try {

con = DriverManager.getConnection(url, user, password); //做这部之前先把ODBC配置好

if (con != null) {

System.out.println("Connection Sucessfully!");

}

} catch (SQLException ex) {

System.out.println(ex.toString());

}

}

public void execute() throws SQLException {

ps = con.prepareStatement("select *from friends"); //SQL语句搞给ps

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/zzgzys.html