Java核心篇之多线程---day1
Java面试之多线程—day1
一. 线程中sleep方法与wait方法有什么区别?
对于 sleep()方法,我们首先要知道该方法是属于 Thread 类中的。而 wait()方法,则是属于Object 类中的。
在调用 sleep()方法的过程中, 线程不会释放对象锁。而当调用 wait()方法的时候,线程会放弃对象锁,进入与该对象相关的等待池中,只有针对此对象当等待时间到了的时候,或者调用 notify()方法后才会返回对象锁。
二. Java中线程的实现方式?同步的方式?
(继承thread类,实现runnable接口,通过callable和future来实现(call方法有返回值和声明异常),使用线程池例如executor框架来实现)
三. 同步锁与死锁
同步锁:当多个线程同时访问同一个数据时,很容易出现问题。为了避免这种情况出现,我们要保证线程
同步互斥,就是指并发执行的多个线程,在同一时间内只允许一个线程访问共享数据。 Java 中可
以使用 synchronized 关键字来取得一个对象的同步锁。死锁:何为死锁,就是多个线程同时被阻塞,它们中的一个或者全部都在等待某个资源被释放。
线程池的原理:
线程池做的工作主要是控制运行的线程的数量,处理过程中将任务放入队列,然后在线程创建后
启动这些任务,如果线程数量超过了最大数量超出数量的线程排队等候,等其它线程执行完毕,
再从队列中取出任务来执行。 他的主要特点为: 线程复用; 控制最大并发数; 管理线程。线程池的组成:
一个线程池主要有四个方面组成:
1. 线程池管理器:用于创建并管理线程池
2. 工作线程:线程池中的线程
3. 任务接口:每个任务必须实现的接口,用于工作线程调度其运行
4. 任务队列:用于存放待处理的任务,提供一种缓冲机制
1. **corePoolSize:指定了线程池中的线程数量。**2. **maximumPoolSize:指定了线程池中的最大线程数量。**3. **keepAliveTime:当前线程池数量超过 corePoolSize 时,多余的空闲线程的存活时间,即多
少时间内会被销毁。**
4. unit: keepAliveTime 的单位。
5. workQueue:任务队列,被提交但尚未被执行的任务。
6. threadFactory:线程工厂,用于创建线程,一般用默认的即可。
7. handler:拒绝策略,当任务太多来不及处理,如何拒绝任务。
- 拒绝策略:
线程池中的线程已经用完了,无法继续为新任务服务,同时,等待队列也已经排满了,再也
塞不下新任务了。这时候我们就需要拒绝策略机制合理的处理这个问题。
JDK 内置的拒绝策略如下:
1. AbortPolicy : 直接抛出异常,阻止系统正常运行。
2. CallerRunsPolicy : 只要线程池未关闭,该策略直接在调用者线程中,运行当前被丢弃的
任务。显然这样做不会真的丢弃任务,但是,任务提交线程的性能极有可能会急剧下降。
3. DiscardOldestPolicy : 丢弃最老的一个请求,也就是即将被执行的一个任务,并尝试再
次提交当前任务。
4. DiscardPolicy : 该策略默默地丢弃无法处理的任务,不予任何处理。如果允许任务丢
失,这是最好的一种方案。
以上内置拒绝策略均实现了 RejectedExecutionHandler 接口,若以上策略仍无法满足实际
需要,完全可以自己扩展 RejectedExecutionHandler 接口。
6. Java线程池的工作原理:
1. 线程池刚创建时,里面没有一个线程。任务队列是作为参数传进来的。不过,就算队列里面
有任务,线程池也不会马上执行它们。
2. 当调用 execute() 方法添加一个任务时,线程池会做如下判断:
a) 如果正在运行的线程数量小于 corePoolSize,那么马上创建线程运行这个任务;
b) 如果正在运行的线程数量大于或等于 corePoolSize,那么将这个任务放入队列;
c) 如果这时候队列满了,而且正在运行的线程数量小于 maximumPoolSize,那么还是要
创建非核心线程立刻运行这个任务;
d) 如果队列满了,而且正在运行的线程数量大于或等于 maximumPoolSize,那么线程池
会抛出异常 RejectExecutionException。
3. 当一个线程完成任务时,它会从队列中取下一个任务来执行。
4. 当一个线程无事可做,超过一定的时间( keepAliveTime)时,线程池会判断,如果当前运
行的线程数大于 corePoolSize,那么这个线程就被停掉。所以线程池的所有任务完成后,它
最终会收缩到 corePoolSize 的大小。
线程与进程的区别:
线程的生命周期(状态)
1. 新建(new):当程序使用 new 关键字创建了一个线程之后,该线程就处于新建状态,此时仅由 JVM 为其分配
内存,并初始化其成员变量的值.
2. 就绪(runnable):当线程对象调用了 start()方法之后,该线程处于就绪状态。 Java 虚拟机会为其创建方法调用栈和
程序计数器,等待调度运行。
3. 运行(running):如果处于就绪状态的线程获得了 CPU,开始执行 run()方法的线程执行体,则该线程处于运行状
态
4. 阻塞(blocked):阻塞状态是指线程因为某种原因放弃了 cpu 使用权,也即让出了 cpu timeslice,暂时停止运行。
直到线程进入阻塞(runnable)状态,才有机会再次获得 cpu timeslice 转到运行(running)状
态。阻塞的情况分三种:
5. 死亡(dead):线程会以下面三种方式结束,结束后就是死亡状态。
start方法和run方法的区别:
1)。 调用start方法来启动多线程,这时候蔡真正的实现多线程运行,这时无需等待run方法执行完毕就可以直接继续执行下面的代码,这个时候线程是处于就绪(runnable) 状态。
2)。run方法称为线程体,调用run方法的时候,线程进入运行态,当run方法执行完毕时,线程就结束了。守护线程
守护线程也叫“服务线程”,为用户提供公共服务,在没有用户可提供的时候会自动离开。守护线程的优先级比较低。
垃圾回收线程就是一个经典的守护线程,当我们程序中不在有其他任何运行的线程时,程序就不会产生垃圾,垃圾回收器也就无事可做,垃圾回收器就会自动离开。
Java核心篇之多线程---day1相关推荐
- Java核心篇之JVM--day3
Java核心篇之JVM--day3 Java JVM详解--通俗易懂教程 JVM:Java虚拟机的简称. 谈到JVM,通常会聊到三个问题: 1. 什么时候触发Java GC? 2. 对什么东西进行Ja ...
- Java核心篇之HashMap--day6
Java核心篇之HashMap–day6 HashMap是一种键值对的数据结构,以数组与链表的形式(key:value)实现,查询性能和添加性能很好.他是通过将key进行hashcode()映射函数来 ...
- Java核心篇之泛型--day5
Java核心篇之泛型–day5 泛型是JDK5时引入的一个新特性,泛型提供了编译时类型安全检查的机制,该机制允许程序猿在编译时检测到非法的类型输入. 泛型的本质是参数化类型,也就是说操作的类型被指定为 ...
- Java核心篇之Redis--day4
Java核心篇之Redis–day4 Redis有哪些数据结构? 字符串String.字典Hash.列表List.集合Set.有序集合SortedSet. 1.String:字符串,常用命令:get, ...
- Java核心篇之Java锁--day2
Java核心篇之Java锁–day2 乐观锁:乐观锁是一种乐观思想,即认为读多写少,每次去取数据的时候都认为其他人不会修改,所以不会上锁:但是在更新的时候会判断一下在此期间别人有没有去修改它,如果有人 ...
- Java核心知识点学习----多线程中的阻塞队列,ArrayBlockingQueue介绍
1.什么是阻塞队列? 所谓队列,遵循的是先进先出原则(FIFO),阻塞队列,即是数据共享时,A在写数据时,B想读同一数据,那么就将发生阻塞了. 看一下线程的四种状态,首先是新创建一个线程,然后,通过s ...
- 第四章Java核心类库_多线程
第四章第五节Java核心类库_多线程 多线程 一.线程与进程 1.线程与进程 2.线程调度 二.同步与异步&并发与并行 1. 同步与异步 2. 并发与并行 三.继承Thread 1.代码块 2 ...
- Java基础篇:多线程
文章目录 1.概念:程序.进程.线程 2.线程的创建和使用 3.线程的生命周期 4.线程的同步 5.线程的通信 6.JDK5.0新增线程创建方法 1.概念:程序.进程.线程 程序(program)是为 ...
- 【JAVA基础篇】多线程
学习Java的多线程知识之前,我们先来了解一下进程和线程的概念,以及他们之间的关系. 进程 基本概念 进程是具有独立功能的程序在某个数据集合上的一次执行过程. 特点 进程是操作系统进行资源分配和调度的 ...
最新文章
- MLPrimitive如何添加自定义的Primitive
- [TJOI2015]线性代数(最小割)
- 网络中工作组与域的解释
- 牛客网 在线编程 猫狗收容所
- HTML是万维网核心语言的第几代,Html5相关的知识点总结
- mysqlbinlog 查看mysql bin 日志 mysqlbinlog: unknown variable 'default-character-set=utf8'
- HTML搜索框中加入提示文字,HTML 5 input placeholder 属性 实现搜索框提示文字点击输入后消失 - 尚码园...
- 风控人应知的坏账准备金知识
- html5实现微信支付宝接口,支付宝H5开放文档
- 解析多层list_基于laravel5.2进行中间件源码的解析
- 虚拟IP技术-VIP 与 负载均衡
- 利用matlab实现卷积实验报告,matlab卷积实验报告(共8篇).doc
- Java聊天室系统的设计与实现(完整源码 sql文件 论文)
- ImageJ下载安装使用
- C# 汉字转拼音(支持GB2312字符集中所有汉字)
- 整流二极管的细节分析
- 单片机两只老虎c语言,蜂鸣器 唱 两只老虎 单片机程序
- P4720 【模板】扩展卢卡斯
- 分布式环境下对部分热数据(如redis热key,热请求)进行探测,并对探测结果及时同步到各个client实例的JVM内存的方案简述
- 支持NDS的视频音频转换软件Xilisoft Video Converter
热门文章
- 使用uuid作为数据库主键,被技术总监怼了!
- ThreadLocal中的3个大坑,内存泄露都是小儿科!
- 阿里巴巴为什么禁止使用Apache Beanutils进行属性复制?
- 阿里面试题BIO和NIO数量问题附答案和代码
- entity framework框架生成摘要文档为空(没有元数据文档可用)的bug解决方案
- int?id与id??1 的意思
- C#中事务的简单使用
- 拦截地址栏参数_selenium操作chrome时的配置参数
- python 发红包import random用redenv,Python微信发红包编码案例 微信发红包的架构模式 - push博客...
- python偶数列表_使用条件偶数列表创建带有地图的元组 - python