多线程细节:

1. 面试题: sleep 方法 和 wait 方法异同点是什么?

相同点: 可以让线程 处于 冻结状态.

不同点:

1.
sleep 必须指定时间
wait 可以指定时间, 也可以不指定时间.

2.

sleep 时间到 线程会处于 临时阻塞 或者运行.

wait 如果没有指定时间 , 必须要通过 notify 或者 notifyAll 唤醒.

3.

sleep 不一定非要定义在 同步中.

wait 必须要定义在同步中. (锁)

4.

都定义在同步中,

线程执行到 sleep, 不会释放锁. (因为 sleep 肯定能醒)

线程执行到 wait, 会释放锁. (wait 就 不一定 能醒)

5.

方法名不相同

// *** 此时的同步代码块中 有多个线程, 不会 出现 线程安全 问题.

// *** 因为里面 的线程 光有执行权是不够的, 还得 需要锁.

synchronized(obj)
{
// sleep(5000); // *** 5000 毫秒, 也就是 5 秒. // *** 释放执行权,

wait(); // *** 0 1 2 // *** 线程池. 这三个 线程 一旦 被唤醒, 都会处于 临时阻塞 状态.

code...

}

synchronized(obj){

notifyAll(); // *** 3 // *** 持有锁.

code...

// *** 释放锁 对于同步代码块 而言 是 隐式的, 会在 同步代码块的最后 释放锁.
}

2. 线程 如何 停止呢?

stop 方法 过时了, 看其 描述发现, 有其它 解决方案.

线程结束: 就是让 线程任务代码 执行完, run 方法结束.

run 方法 咋结束呢?

run 方法中 通常都定义 循环, (如果没有定义循环 就不要 开启 多线程了, 没有意义.), 只要 控制循环 就 哦了.

*** 注意: 万一线程 在 任务中 处于了 冻结状态, 那么 它 还能去判断标记吗? 不能!

咋办? 答: *** 通过 查阅 stop 方法的描述, 发现提供了一个 解决方法, 如果目标线程 等待很长时间, 则 应使用 interrupt 方法来 中断等待.

所谓的 中断 并不是 停止线程.

*** interrupt 功能是 将线程 的 冻结状态 清除, 让线程 恢复到 运行状态(让 线程 重新 具备 CPU 的执行资格).

*** interrupt 让线程 从 冻结状态 恢复 回来. 清除 其 中断 状态.

*** 因为是 强制性的, 所以会有 异常发生, 可以在 catch 中 捕获异常, *** 在 异常处理中, 改变标记 让 循环结束, 让 run 方法结束.

3. 守护线程: 后台线程, 一般创建的 都是前台线程。

前台 后台 线程运行时 都是一样的, 获取 CPU 的执行权执行。

只有结束的时候有些不同。

前台线程要通过 run 方法结束, 线程结束。

后台线程 也可以通过 run 方法结束, 线程结束, 还有另一种情况,

当进程中 所有的前台线程都 结束了, 这时 无论后台线程 处于什么样的状态, 都会结束 , 从而 进程结束。

进程结束 依赖的 都是 前台线程。

之所以这里称之为 守护线程, 无非是 后台线程 在 守护着 前台线程。

前台 线程们结束了, 后台 线程 就自动跟着 结束了。

4. 线程 的 优先级: 是 用 数字标识的: 1-10

其中默认 初始优先级 是 5。 最明显的 三个 优先级 1, 5, 10

setPriority(10); // *** 设置线程 的优先级。

setPriority(Thread.MAX_PRIORITY);

setPriority(Thread.MIN_PRIORITY);

setPriority(Thread.NORM_PRIORITY);

5. 线程组: ThreadGroup: 可以通过 Thread 的 构造函数 明确 新 线程对象 所属的 线程组。

线程组的好处: 可以对 多个 同组的线程, 进行 统一的操作。

默认都属于 main 线程组。

6. 线程 是可以 自己 取名字的。

例如:

Thread t1 = new Thread(d,"旺财"); // *** 旺财 线程名

Thread t2 = new Thread(d,"小强"); // *** 小强 线程名

可以自己 给 线程 取名 以 增强 程序的 阅读性。

例如:

输入线程, 运行线程 etc.

7. join 方法

主线程执行到这里, 知道 t1 要加入 执行, 主线程 释放了 执行权、 执行资格 并处于 冻结状态, 什么时候恢复呢?

等 t1 线程 执行完。
try{t1.join();}catch(InterruptedException e){}

try{t1.join();}catch(InterruptedException e){} // *** 一般这个方法 用于 临时 加入一个 运算的线程, 让 该 线程 运算完, 程序才会继续执行。

8. yield(); (static 静态的)

// *** 暂停 当前正在 执行的线程对象, 并执行 其它 线程。

Thread.yield(); // *** 线程 临时暂停。 将执行权 释放, 让其他 线程 有机会 获取 执行权。

// *** 嵌套类 也就是 内部类。

9. 开发中, 线程 匿名内部类 体现。

// *** 面试题

new Thread(new Runnable() // *** 就是 往里面 传递了 一个 线程任务 对象。 在 执行的时候, 就按照 这个对象的 任务来执行。
{
public void run(){
}

}).start();

// *** 面试题

new Thread(new Runnable() // *** 就是 往里面 传递了 一个 线程任务对象。 在 执行的时候, 就按照 这个对象的 任务来执行。
{
public void run(){

System.out.println("runnable run");
}

}){

public void run(){

System.out.println("subthread run");
}

}.start();

}

 public class ThreadTest{

     public static void main(String[] args) {

     /*
// *** 使用 匿名内部类的方式 创建一个 线程。
new Thread(){ // *** 这是一个 Thread 的子类对象, 可以 进行 覆盖 run 方法的操作。 public void run(){ for(int x = 0; x < 40; x++){
System.out.println(Thread.currentThread().getName() +"....X...." + x);
}
} }.start(); Runnable r = new Runnable(){ public void run(){ for(int x = 0; x < 40; x++){
System.out.println(Thread.currentThread().getName() +"....Y...." + x);
} } }; new Thread(r).start(); for(int x = 0; x < 40; x++){
System.out.println(Thread.currentThread().getName() +"....Z...." + x);
} */ // *** 面试题 new Thread(new Runnable() // *** 就是 往里面 传递了 一个 线程任务对象。 在 执行的时候, 就按照 这个对象的 任务来执行。
{
public void run(){ System.out.println("runnable run");
} }){ public void run(){ System.out.println("subthread run"); // *** 执行
} }.start(); // new Thread 后面是一个 大括号, 就是一个 子类. }
//*** 子类 覆盖 父类, 运行的 时候 运行的 是 子类 方法. } /* class Thread{ private Runnable r;
Thread(Runnable r)
{ this.r = r; } public void run(){ if(r != null){ r.run(); // *** 这里调用的 是 Runnable 的 run 方法. } } public void start(){ run(); } } class SubThread extends Thread{ // *** 子类 覆盖 父类, 运行的 时候 运行的 是 子类 方法. public void run(){ System.out.pritnln("subthread run");
} } Runnable r = new Runnable();
{ public void run(){ System.out.println("runnable run"); } }
//Thread t = new Thread(r); SubThread t = new SubThread(r); t.start(); // *** 这里先 调用 start 方法, 然后 调用 run 方法, 然后 判断 r 不为空, 然后 调用 Runnable 的 run 方法(因为 传进去的 参数 是 Runnable 的 对象 r), 然后 输出 runnable run. */

关于 Java 中多线程的面试问题 详解的更多相关文章

  1. Java 中的异常和处理详解

    Java 中的异常和处理详解 原文出处: 代码钢琴家 简介 程序运行时,发生的不被期望的事件,它阻止了程序按照程序员的预期正常执行,这就是异常.异常发生时,是任程序自生自灭,立刻退出终止,还是输出错误 ...

  2. 关于Java中进程和线程的详解

    一.进程:是程序的一次动态执行,它对应着从代码加载,执行至执行完毕的一个完整的过程,是一个动态的实体,它有自己的生命 周期.它因创建而产生,因调度而运行,因等待资源或事件而被处于等待状态,因完成任务而 ...

  3. java中内存结构及堆栈详解

    一. java内存结构 1. Heap(堆):实例分配的地方,通过-Xms与-Xmx来设置 2. MethodArea(方法区域):类的信息及静态变量. 对应是Permanet Generation, ...

  4. Java中的异常和处理详解

    简介 程序运行时,发生的不被期望的事件,它阻止了程序按照程序员的预期正常执行,这就是异常.异常发生时,是任程序自生自灭,立刻退出终止,还是输出错误给用户?或者用C语言风格:用函数返回值作为执行状态?. ...

  5. JAVA中的String类(详解)

    Java.lang.String类是final类型的,因此不可以继承这个类.不能修改这个类.String是一个类不属于基本数据类型. 可以从源码中看到,String是一个final类型. String ...

  6. Java 中的异常和处理详解(转载)

    原文出处: 代码钢琴家 简介 程序运行时,发生的不被期望的事件,它阻止了程序按照程序员的预期正常执行,这就是异常.异常发生时,是任程序自生自灭,立刻退出终止,还是输出错误给用户?或者用C语言风格:用函 ...

  7. Java中的异常和处理详解(转发:https://www.cnblogs.com/lulipro/p/7504267.html)

    简介 程序运行时,发生的不被期望的事件,它阻止了程序按照程序员的预期正常执行,这就是异常.异常发生时,是任程序自生自灭,立刻退出终止,还是输出错误给用户?或者用C语言风格:用函数返回值作为执行状态?. ...

  8. 2018.8.1 Java中的反射和同步详解

    为何要使用同步? java允许多线程并发控制,当多个线程同时操作一个可共享的资源变量时(如数据的增删改查), 将会导致数据不准确,相互之间产生冲突,因此加入同步锁以避免在该线程没有完成操作之前,被其他 ...

  9. java中ReentrantLock核心源码详解

    ReentrantLock简介 ReentrantLock是一个可重入且独占式的锁,它具有与使用synchronized监视器锁相同的基本行为和语义,但与synchronized关键字相比,它更灵活. ...

随机推荐

  1. netty源码解解析(4.0)-23 ByteBuf内存管理:分配和释放

    ByteBuf内存分配和释放由具体实现负责,抽象类型只定义的内存分配和释放的时机. 内存分配分两个阶段: 第一阶段,初始化时分配内存.第二阶段: 内存不够用时分配新的内存.ByteBuf抽象层没有定义 ...

  2. js常用Matn函数的操练

    Math.PI console.log(Math.PI); 随机数以及向下取整 这是一个能实现从a-b之间随机打印一个整数 function rand_s(a, b) { var x = a + (b ...

  3. Java通过JDK动态代理简单的实现一个AOP

    首先说一下,因为自己还没有去研读spring的AOP的源码,只是大致知道其功能,便想着自己先手动实现一个先看看,觉得这样以后研读源码的时候会收获更多! 实现:做一个在添加注解的方法执行之前,可以先执行 ...

  4. idea中的java web项目(添加jar包介绍)和java maven web项目目录结构

    java web项目 web项目下web根目录名称是可以更改的 idea中新建java web项目,默认src为Sources Root,当然也可以手动改,在Sources Root下右键只能新建Pa ...

  5. ef core实现软删除

    很多web程序一般的偶不会设计真的物理删除了. 基本上都是在在数据库加一个标记,就得当作已经删除了.同时在查询的时候,过滤已经标记删除的数据 ef core实现软删除是非常简单的,直接在OnModel ...

  6. Spring-Data-Jpa使用总结

    参考资源列表 官方文档:https://docs.spring.io/spring-data/jpa/docs/2.1.5.RELEASE/reference/html/ <Spring Dat ...

  7. VUE--插值的操作

    一.vue常见的指令 v-once:保留第一次渲染结果 v-html :把html代码解析,只显示内容 v-pre :原样输出 v-cloak :解决文本闪烁问题 v-text :显示文本 二.v-b ...

  8. CH3803扑克牌

    Description 背景 lqhsr生日那天,Rainbow来找lqhsr玩扑克牌-- 玩着玩着Rainbow觉得太没意思了,于是决定给lqhsr一个考验~~~ 描述 Rainbow把一副扑克牌( ...

  9. abp(net core)+easyui+efcore实现仓储管理系统——EasyUI之货物管理五 (二十三)

    abp(net core)+easyui+efcore实现仓储管理系统目录 abp(net core)+easyui+efcore实现仓储管理系统——ABP总体介绍(一) abp(net core)+ ...

  10. Zabbix 2.2系列注入+getsehll

    Zabbix 是一个开源的企业级性能监控解决方案. 官方网站:http://www.zabbix.com Zabbix 的jsrpc的profileIdx2参数存在insert方式的SQL注入漏洞,攻 ...