1.并行和并发有什么区别
1.并行:指两个或者多个事件在同一时刻发生,即同时做不同事的能力。例如垃圾回收时,多条垃圾收集线程并行工作,但此时用户线程任然处于等待状态。
2.并发:指两个或多个事件在同一时间间隔内发生,即交替做不同事的能力,多线程是并发的一种形式。例如垃圾回收时,用户线程与垃圾收集线程同时执行(但不一定是并行的,可能会交替执行),用户程序在继续运行,而垃圾收集程序运行于另一个CPU上
2.守护线程是什么?
1.守护线程又称为后台线程,它独立于控制终端并且周期性地执行某种任务或等待处理某些发生的事件
2.正常创建的线程都是普通线程,或称为前台线程,守护线程与普通线程在使用上没有什么区别,主要区别在进程的结束中。当一个进程中所有普通线程都结束是,那么进程就会结束。如果进程结束时还有守护线程在运行,那么这些守护线程就会被强制结束
3.在java中垃圾回收线程就是特殊的守护线程。
3.创建线程有哪几种方式
1.继承Thread类是Runnable接口的实现
2.实现Runnable接口,并重写里面的run方法
3.使用Executor框架创建线程池。Executor框架是juc里提供的线程池的实现
4.sleep()和wait()有什么区别
1.类的不同:sleep()来自Thread,wait()来自Object。
2.释放锁:sleep()不释放锁;wait()释放锁。
3.用法不同:sleep()时间到会自动恢复;wait()可以使用notify()/notifyAll()直接唤醒。
5.线程run()和start()有什么区别
1.start()方法用于启动线程,run()方法用于执行线程的运行时代码
2.run()可以重复调用,而start()只能调用一次
3.第二次调用start()必然会抛出运行时异常
6.创建线程池有哪几种方式?
1)newCachedThreadPool创建一个可缓存线程池
2)newFixedThreadPool 创建一个定长线程池,可控制线程最大并发数。
3)newScheduledThreadPool 创建一个定长线程池,支持定时及周期性任务执行。
4)newSingleThreadExecutor 创建一个单线程化的线程池,它只会用唯一的工作线程来执行任务。
7.在java程序中怎么保证多线程的运行安全
线程同步:使用多个线程访问同一资源的时候,且多个线程中对资源有写的操作,就容易出现线程安全问题,java中提供了同步机制(synchronized)来解决。有3种方法
1.同步代码块(synchronized的锁是Object)
2.同步方法(定义一个方法,加synchronized,它的锁是this)
3.锁机制(lock)
8.什么是死锁?怎么防止死锁?
死锁:AB两个线程由于互相持有对方需要的锁,而发生的阻塞现象,称为死锁。
防止死锁的方法:
(1)尽量使用tryLock(long timeout, TimeUnit unit)的方法(ReentrantLock、ReentrantReadWriteLock),设置超长时间,超时可以退出防止死锁。
(2)尽量使用Java.util.concurrent并发类代替自己手写锁
(3)尽量降低锁的使用粒度,尽量不要几个功能用同一把锁
(4)尽量减少同步代码块
9.synchronized和volatile的区别是什么?
1.volatile是变量修饰符;synchronized是修饰类、方法、代码段。
2.volatile仅能实现变量的修改可见性,不能保证原子性;synchronized 则可以保证变量的修改可见性和原子性。
3.volatile不会造成线程的阻塞;synchronized 可能会造成线程的阻塞.
10.synchronized 和 Lock 有什么区别?
1.synchronized 可以给类、方法、代码块加锁;而 lock 只能给代码块加锁.
2.synchronized 不需要手动获取锁和释放锁,使用简单,发生异常会自动释放锁,不会造成死锁;而 lock 需要自己加锁和释放锁,如果使用不当没有 unLock()去释放锁就会造成死锁。
3.通过 Lock 可以知道有没有成功获取锁,而 synchronized 却无法办到。
11.synchronized 和 ReentrantLock 区别是什么?
1.ReentrantLock 使用起来比较灵活,但是必须有释放锁的配合动作;
2.ReentrantLock 必须手动获取与释放锁,而 synchronized 不需要手动释放和开启锁;
3.ReentrantLock 只适用于代码块锁,而 synchronized 可用于修饰方法、代码块等。
12.为什么使用线程池?
由于创建和销毁都需要很大的开销,运用线程池就可以大大的缓解这些内存开销很大的问题;可以根据系统的承受能力,调整线程池工作线程的数目,防止因为消耗过多的内存。
|