Java面试题精选(二)线程编程、数据库理论和Jdbc部分(一)

2014-11-24 08:17:32 · 作者: · 浏览: 2

线程编程方面:

1sleep() wait() 有什么区别 ★★
答:

sleep是线程类(Thread)的方法,导致此线程暂停执行指定时间,给执行机会给其他线程,但是监控状态依然保持,

到时后会自动恢复。

调用sleep不会释放对象锁。
wait是Object类的方法,对此对象调用wait方法导致本线程放弃对象锁,进入等待此对象的等待锁定池,

只有针对此对象发出notify方法(或notifyAll)后本线程才进入对象锁定池准备获得对象锁进入运行状态。

2、同步和异步有何异同,在什么情况下分别使用他们?举例说明。
答:

如果数据将在线程间共享。例如正在写的数据以后可能被另一个线程读到,或者正在读的数据可能已经被另一个线程写过了,

那么这些数据就是共享数据,必须进行同步存取。
当应用程序在对象上调用了一个需要花费很长时间来执行的方法,并且不希望让程序等待方法的返回时,就应该使用异步编程

在很多情况下采用异步途径往往更有效率。

3、启动一个线程是用run()还是start() ★★★
答:

启动一个线程是调用start()方法,使线程所代表的虚拟处理机处于可运行状态,这意味着它可以由JVM调度并执行。

这并不意味着线程就会立即运行。run()方法可以产生必须退出的标志来停止一个线程。

4、当一个线程进入一个对象的一个synchronized方法后,其它线程是否可进入此对象的其它方法
答:不能,一个对象的一个synchronized方法只能由一个线程访问。

5、请说出你所知道的线程同步的方法。
答:wait():使一个线程处于等待状态,并且释放所持有的对象的lock。
sleep():使一个正在运行的线程处于睡眠状态,是一个静态方法,

调用此方法要捕捉InterruptedException异常。
notify():唤醒一个处于等待状态的线程,注意的是在调用此方法的时候,

并不能确切的唤醒某一个等待状态的线程,而是由JVM确定唤醒哪个线程,且不是按优先级。
Allnotity():唤醒所有处入等待状态的线程,注意并不是给所有唤醒线程一个对象的锁,而是让它们竞争。

6、多线程有几种实现方法,都是什么 同步有几种实现方法,都是什么
答:

多线程有两种实现方法,分别是继承Thread类与实现Runnable接口 。
同步的实现方面有两种,分别是synchronized,wait与notify 。

7、线程的基本概念、线程的基本状态以及状态之间的关系★★★★
答:

线程指在程序执行过程中,能够执行程序代码的一个执行单位,每个程序至少都有一个线程,也就是程序本身。
Java中的线程有五种状态分别是:创建、运行、就绪、阻塞、结束。

8、简述synchronizedjava.util.concurrent.locks.Lock的异同
答:

主要相同点:Lock能完成synchronized所实现的所有功能
主要不同点:Lock有比synchronized更精确的线程语义和更好的性能。synchronized会自动释放锁,

而Lock一定要求程序员手工释放,并且必须在finally从句中释放。

9、java中有几种方法可以实现一个线程?用什么关键字修饰同步方法 stop()和suspend()方法为何不推荐使用?

答:有两种实现方法,分别是继承Thread类与实现Runnable接口;

用synchronized关键字修饰同步方法; 反对使用stop(),是因为它不安全。它会解除由线程获取的所有锁定,而且如果对象处于一种不连贯状态,那么其他线程能在那种状态下检查和修改它们。结果很难检查出真正的问题所在;

数据库理论归纳:

执行顺序:

  select... from... where... group by... having ...order by...的执行顺序
(from)(where)(group by)(having)(select)(order by) 增、删、改、建 :
建:create table tabname(col1 , col2 ...);
增:insert into tabname values (values);
改:update tabname set colname = values , colname = values where colname = values;
    (注意,修改多列值的时候,要用 逗号 隔开,不可以用 and 连接)
删:delete from tabname where condition ...
    delete tabname .

日期函数转换:to_char      数值转换字符
              to_number    字符转换数值
              to_date      转换日期格式

非关联子查询: select ... from ...where ..in + (select语句 如:select id from account where ...);
关联子查询 :  select ... from ...where ...exists + (select语句 如:select 1 from account where ...);
交叉连接 :    cross join  每个记录相互连接得出匹配和不匹配问题
内连接 :      (inner) join  解决匹配问题。
外连接 :       (outer) join  解决不匹配问题。
拓展-> 左连接 右连接 :  left join  ; right join  区分匹配表、驱动表的关系

集合运算符:  union/ union all  并集  (集合不重复/集合存在重复)            
              intersect   交集  (取两个表共同存在的集合元素)
              minus    差值   (一个表是另一个表的子集)
排名分页 :     rownum 解决对结果集进行编号排列
              (rowid)  通常和 index 索引 相提 
约束(constraint):  主键 : primary key  约束名可不写,不可为null和重复值
                    唯一键:unique key   理解联合唯一与联合主键的写法, 可为null值                                                                            
                    外键 :references ...(表级约束)    列级约束:foreign key ... references ...
                    检查 :check     理解联合检查的写法
                    非空 :not null   只有列级约束的形式 事务: transaction
数据定义语言: Data Definition Language
数据操作语言: Data Manipulation Language
事务控制语言: Transaction Control Language
数据查询语言: Data Query Language
数据控制语言: Data Control Language

on delete cascade  级联删除
on delete set null  删除值 置空 

视图

创建: create or replace view view_name as/is + select 语句

视图恢复:alter view view_name compile

删除: drop view view_name

with check option 检查插入记录是否符合where条件

with read only 只能查询,不能做DML操作

索引 : create index ind_name on tabname(colname...).

对视图可以做 desc 和 select 操作 ,对索引则不可以。

序列号: create sequence seq_name

start with ...起始值 increment by .