Java并发程序设计(一) 基础概念 一.必须知道的几个概念 一)同步(Synchronous)和异步(Asynchronous) 同步:同步方法调用一旦开始,调用者必须等到方法调用返回后,才能继续后续的行为. 异步:一旦开始,方法调用就立即返回,调用者就可以继续后续的操作. 二)并发(Concurrency)和并行(Parallelism) 共同点:都可以表示多个任务一起执行. 并发:偏重于多个任务交替执行,多个任务之间还可能是串行的. 并行:同时执行. 三)临界区 一种用来存储公共资源或者共…
java并发编程 线程基础 1. java中的多线程 java是天生多线程的,可以通过启动一个main方法,查看main方法启动的同时有多少线程同时启动 public class OnlyMain { public static void main(String[] args) { //虚拟机线程管理接口 ThreadMXBean threadMXBean = ManagementFactory.getThreadMXBean(); ThreadInfo[] threadInfos = thre…
并发编程的一些概念 同步和异步 同步: 同步方法必须等到方法调用返回后,才能继续后继的行为.也就是说,同步方法执行时,如果没有返回,则后面的方法是执行不到的.同步方法调用,调用过程中可能出现阻塞和等待. 比如说,java读取控制台输入就是同步方法. 异步: 异步方法调用后立即返回,可以立即执行后继的方法.异步方法的返回结果,采用通知的方式来告知调用者.异步方法调用,调用过程中不会出现阻塞和等待. 举个例子:js的ajax方法就默认是异步调用的,执行后马上返回,继续执行下面的代码.如果你想操作结果…
Java并行程序基础 一.线程的生命周期 其中blocked和waiting的区别: 作者:赵老师链接:https://www.zhihu.com/question/27654579/answer/128050125来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明出处. 假设t1,t2先后两个线程,都执行如下代码: synchronized(Obj) { Obj.wait(); } t1先进,最后在Obj.wait()下卡住,这时java管t1的状态waitting状态t…
一,JDK并发包实际上就是指java.util.concurrent包里面的那些类和接口等 主要分为以下几类: 1,原子量:2,并发集合:3,同步器:4,可重入锁:5,线程池 二,原子量 原子变量主要有AtomicInteger,AtomicLong,AtomicBoolean等, 主要实现原理都是底层实现类CAS 即比较并交换,都有get,set,compareAndSet等方法,如++,--等也都是有自带方法实现 这些都是线程安全的,保证了多线程访问时候的可见性 import java.ut…
1. 基本概念 程序,是一组有序的静态指令,是一种静态的概念.程序的封闭性是指程序一旦运行,其结果就只取决于程序本身:程序的再现性是指当机器在同一数据集上重复执行同一程序时,机器内部的动作系列完全相同,最后获得的结果也相同. 进程,是一种活动,它是由一个动作系列组成,每个动作是在某个数据集上执行一段程序,整个活动结果是提供一处系统或用户功能.进程一般由三部分组成:程序.数据集合.进程控制块(PCB).进程具有并发性和不确定性. 线程,是一个进程内部的顺序控制流.线程本身不能独立运行,必须在进程中…
在学习多线程编程时,相信大家会遇到好多概念类的东西,对于这些概念的不准确理解会导致后面越学越糊涂,现将学习过程中遇到的概念整理到这篇博客上,一来记录学习点滴,二来也加深理解,如果有理解不准确的地方,希望大家指出. 参考与并发编程网 http://ifeve.com/java-concurrency-thread-directory/ 临界区:临界区是一段代码,这段代码可能会导致竞态条件的发生,所谓竞态条件就是多个线程不同的执行顺序可能导致不同的结果,这样的情况就称存在竞态条件 不可变性:对象没有…
1.创建线程的方式: /** * StudySjms * <p> * Created by haozb on 2018/2/28. */ public class ThreadDemo extends Thread { /** * 定义线程的名字 * @param name */ public ThreadDemo(String name) { super(name); } @Override public void run() { ; i < ; i++) { System.out.p…
本章会介绍一些最有用的并发构建模块,有丶东西(最后一小节,纯干货). 5.1 同步容器类 同步容器类包括 Vector 和 Hashtable ,这些类实现线程安全的方式是:将它们的状态封装起来,并对每个公有方法都进行同步,使得每次只有一个线程能访问容器的状态. 5.1.1 同步容器类的问题 同步容器类都是线程安全的,但在某些情况下可能需要额外的客户端加锁来保护符合操作.容器上常见的复合操作包括:迭代(反复访问元素,直到遍历完容器中所有元素).跳转(根据指定顺序找到当前元素的下一个元素)以及条件…
一.Java 简介: Java 是由 Sun Microsystems 公司于 1995 年 5 月推出的 Java 面向对象程序设计语言和 Java 平台的总称. 由 James Gosling和同事们共同研发,并在 1995 年正式推出.后来 Sun 公司被 Oracle (甲骨文)公司收购, Java 也随之成为 Oracle 公司的产品 Java分为三个体系: 1.1.JavaSE(J2SE)(Java2 Platform Standard Edition,java平台标准版) 1.2.…