标签:工作 对比 ssi 用户 功能 unit reads rmi term
多线程2.线程和进程的区别?
一个程序下至少有一个进程,一个进程下至少有一个线程,一个进程下也可以有 多个线程来增加程序的执行速度。
3.守护线程是什么?
守护线程是运行在后台的一种特殊进程。它独立于控制终端并且周期性地执行某 种任务或等待处理某些发生的事件。在 Java 中垃圾回收线程就是特殊的守护线 程。
4.创建线程有哪几种方式?
创建线程有三种方式: 继承 Thread 重新 run 方法; 实现 Runnable 接口; 实现 Callable 接口。
5.说一下 runnable 和 callable 有什么区别?
runnable 没有返回值,callable 可以拿到有返回值,callable 可以看作是 runnable 的补充。
6.线程有哪些状态?
线程的状态: NEW 尚未启动
RUNNABLE 正在执行中 BLOCKED 阻塞的(被同步锁或者 IO 锁阻塞) WAITING 永久等待状态 TIMED_WAITING 等待指定的时间重新被唤醒的状态 TERMINATED 执行完成
7.sleep() 和 wait() 有什么区别?
类的不同:sleep() 来自 Thread,wait() 来自 Object。 释放锁:sleep() 不释放锁;wait() 释放锁。 用法不同:sleep() 时间到会自动恢复;wait() 可以使用 notify()/notifyAll()直接唤 醒。
8.notify()和 notifyAll()有什么区别?
notifyAll()会唤醒所有的线程,notify()之后唤醒一个线程。
notifyAll() 调用后,会 将全部线程由等待池移到锁池,然后参与锁的竞争,竞争成功则继续执行,如果 不成功则留在锁池等待锁被释放后再次参与竞争。
而 notify()只会唤醒一个线程, 具体唤醒哪一个线程由虚拟机控制。
9.线程的 run() 和 start() 有什么区别?
start() 方法用于启动线程,run() 方法用于执行线程的运行时代码。run() 可以重 复调用,而 start() 只能调用一次。
10.创建线程池有哪几种方式?
线程池创建有七种方式,最核心的是最后一种:
newSingleThreadExecutor():它的特点在于工作线程数目被限制为 1,操作一个 ***的工作队列,所以它保证了所有任务的都是被顺序执行,最多会有一个任务 处于活动状态,并且不允许使用者改动线程池实例,因此可以避免其改变线程数 目;
newCachedThreadPool():它是一种用来处理大量短时间工作任务的线程池,具有 几个鲜明特点:它会试图缓存线程并重用,当无缓存线程可用时,就会创建新的 工作线程;如果线程闲置的时间超过 60 秒,则被终止并移出缓存;长时间闲置 时,这种线程池,不会消耗什么资源。其内部使用 SynchronousQueue 作为工作 队列; newFixedThreadPool(int nThreads):重用指定数目(nThreads)的线程,其背后使 用的是***的工作队列,任何时候最多有 nThreads 个工作线程是活动的。这意 味着,如果任务数量超过了活动队列数目,将在工作队列中等待空闲线程出现; 如果有工作线程退出,将会有新的工作线程被创建,以补足指定的数目 nThreads;
newSingleThreadScheduledExecutor() : 创 建 单 线 程 池 , 返 回 ScheduledExecutorService,可以进行定时或周期性的工作调度;
newScheduledThreadPool(int corePoolSize):和 newSingleThreadScheduledExecutor() 类似,创建的是个 ScheduledExecutorService,可以进行定时或周期性的工作调 度,区别在于单一工作线程还是多个工作线程; newWorkStealingPool(int parallelism):这是一个经常被人忽略的线程池,Java 8 才 加入这个创建方法,其内部会构建 ForkJoinPool,利用 Work-Stealing 算法,并行 地处理任务,不保证处理顺序;
ThreadPoolExecutor():是最原始的线程池创建,上面 1-3 创建方式都是对 ThreadPoolExecutor 的封装。
11.线程池都有哪些状态?
RUNNING:这是最正常的状态,接受新的任务,处理等待队列中的任务。
SHUTDOWN:不接受新的任务提交,但是会继续处理等待队列中的任务。
STOP:不接受新的任务提交,不再处理等待队列中的任务,中断正在执行任务的 线程。
TIDYING:所有的任务都销毁了,workCount 为 0,线程池的状态在转换为 TIDYING 状态时,会执行钩子方法 terminated()。
TERMINATED:terminated()方法结束后,线程池的状态就会变成这个。 线程池中 submit() 和 execute() 方法有什么区别? execute():只能执行 Runnable 类型的任务。
submit():可以执行 Runnable 和 Callable 类型的任务。
Callable 类型的任务可以获取执行的返回值,而 Runnable 执行无返回值。
12.在 Java 程序中怎么保证多线程的运行安全?
方法一:使用安全类,比如 Java. util. concurrent 下的类。
方法二:使用自动锁 synchronized。
方法三:使用手动锁 Lock。 手动锁 Java 示例代码如下: Lock lock = new ReentrantLock(); lock. lock(); try { System. out. println(“获得锁”); } catch (Exception e) { // TODO: handle exception } finally { System. out. println(“释放锁”); lock. unlock();
}
标签:工作 对比 ssi 用户 功能 unit reads rmi term
原文地址:https://blog.51cto.com/14760318/2486660