1.Set集合有什么特点?如何实现key无重复的?
2.有序的Set是什么?记录插入顺序的集合是什么?
3.java里面的线程和操作系统的线程一样吗?
4.使用多线程要注意哪些问题?
5.保证数据的一致性有哪些方案呢?
6.线程的创建方式有哪些?
7.怎么启动线程 ?
8.如何停止一个线程的运行?
9.调用 interrupt 是如何让线程抛出异常的?
10.Java线程的状态有哪些?
1.Set集合有什么特点?如何实现key无重复的?
Set集合内的元素是唯一的。
原理是先计算hashcode,确定存储位置,然后通过equals判断是都相同。
2.有序的Set是什么?记录插入顺序的集合是什么?
TreeSet(大小排序,红黑树)和LinkedHashSet(双向链表,自然插入顺序)。

3.java里面的线程和操作系统的线程一样吗?
Java 中线程的本质,其实就是操作系统中的线程,由于Java语言通过JVM来封装底层操作系统的差异,所以Java线程也必然会将不同操作系统的线程进行封装,并提供一个统一的并发定义。比如在 Windows 中 Java 就是基于 Wind32 线程库来管理线程,且 Windows 采用的是一对一的线程模型。
进程,是对运行时程序的封装,是系统进行资源调度和分配的基本单位,实现了操作系统的并发。
线程,是进程的子任务,是 CPU 调度和分派的基本单位,实现了进程内部的并发。
4.使用多线程要注意哪些问题?
可见性,原子性和有序性。
可见性是一个线程改变某一变量,其他线程是可以感受到的。
原子性,是同一时刻只有一个线程对数据进行操作。

5.保证数据的一致性有哪些方案呢?
事务管理,对于数据库的操作,使用事务管理,确保一组数据库操作,那么全部成功,要么全部失败。通过ACID(原子性、一致性、隔离性、持久性)属性,数据库事务可以保证数据的一致性。
锁机制,实现对共享变量的互斥访问,例如synchronized,RReentrantLock,vilatiled等。
版本控制,乐观锁,例如CAS等,在更新数据的时候记录数据的版本,确保要更新对象并没有被其他线程修改。
6.线程的创建方式有哪些?
1.创建一个类继承 Thread 类,并重写 run 方法。
MyThread t = new MyThread();
t.start();
2.创建一个类实现 Runnable 接口,并重写 run 方法。(第一二种方法都是直接实例化一个对象,然后start()就行,更好,避免了单继承的局限性。)
Thread t = new Thread(new MyRunnable());
t.start();
3.实现 Callable 接口,重写 call 方法,这种方式可以通过 FutureTask 获取任务执行的返回值。(使用最麻烦)
//创建异步任务
FutureTask<String> task=new FutureTask<String>(new CallerTask());
//启动线程
new Thread(task).start();
try {
//等待执行完成,并获取返回结果
String result=task.get();
4.使用线程池(Executor框架)
ExecutorService executor = Executors.newFixedThreadPool(10);
for (int i = 0; i < 100; i++) {
executor.submit(new Task());
}
executor.shutdown();
run():封装线程执行的代码,直接调用相当于调用普通方法。
start():启动线程,然后由 JVM 调用此线程的 run() 方法。
7.怎么启动线程 ?
启动线程的通过Thread类的start()。
8.如何停止一个线程的运行?
1.stop方法,因为会导致一些清理工作没办法处理,所以就被抛弃了。
2.自定义标记,在run方法中判断,这会使得中断不及时。
3.使用interrupt中断线程。使用 interrupt 方法可以给执行任务的线程,发送一个中断线程的指令,它并不直接中断线程,而是发送一个中断线程的信号,把是否正在中断线程的主动权交给代码编写者。相比于自定义中断标识符而然,它能更及时的接收到中断指令。
9.调用 interrupt 是如何让线程抛出异常的?
线程处于阻塞状态,如Thread.sleep、wait、IO阻塞等情况时,调用interrupt方法后,sleep等方法将会抛出一个InterruptedException:

10.Java线程的状态有哪些?
7个状态。
可以调用线程Thread中的getState()方法获取当前线程的状态。

11万+

被折叠的 条评论
为什么被折叠?



