第一章
 
线程共享进程范围内的资源,但每个线程都有各自的程序计数器、栈以及局部变量等。
多个线程可以同时调度到多个CPU上运行。
 
线程的优势?
在服务应用程序中,可以提升资源利用率以及系统吞吐率,发挥多处理器的强大功能。
 
线程的优先级  执行时间  线程切换需要额外的开销
 
第二章
 
如果多个线程访问同一个可变的状态变量是没有使用合适的同步,那么程序就会出现错误,有以下三种方法修复这种问题。
1、不在线程之间共享该状态变量
2、将状态变量改为不可变的变量
3、在访问状态变量时使用同步
 
什么是线程安全?自己百度
 
无状态对象一定是线程安全的
 
注意count++这类操作的问题:不是原子的,实际上是三部操作 读取-修改-写入
 
什么是竞态条件?
在并发编程中,由于不恰当的执行时序从而使得结果变得不可靠。常见的竞态条件类型就是“先检查后执行” ,例如常见的对象懒加载
 
一个包:java.concurrent.atomic
 
 
内置锁:加锁机制,java中用于确保原子性的内置机制。同步代码块、同步方法
以synchronized来修饰的方法叫同步方法,该同步代码块的锁就是方法调用所在的对象,静态的 synchronized方法以Class对象作为锁
 
每个java对象都可以用作实现一个同步的锁,称为内置锁或监视器锁。
线程在进入同步代码块前会自动获得锁,并且在退出同步代码块时自动释放锁。
 
内置锁是可重入的。
 
理解一句话:状态变量是由这个锁保护的。
 
锁不要滥用,同步代码块太大会引起不良并发,大大拉低程序性能。当执行较长的计算或者可能无法快速完成的操作时(如网络I/O、控制台I/O),一定不要持有锁。
 
第三章
 
同步机制不只是为了实现原子性或者确定“临界区”,还确保了多个线程之间对内存操作的可见性。
加锁的含义不仅仅局限于互斥行为,还包含内存可见性。
 
注意重排序现象
 
最低安全性:当线程在没有进行同步的情况下读取变量时,可能会的到一个时效值,但至少这个值是由之前某个线程设置的,而不是一个随机值。
非volatile类型的64位数值变量(double和long)不适用于最低安全性,因为JVM允许将64位的读操作或写操作分解为两个32位的操作
 
一种稍弱的同步机制,即volatile变量。
加锁机制即可以确保可见性又可以确保原子性,而volatile变量只能确保可见性。(确保只有单个线程更新变量的值时可以用 volatile变量 )
 
发布一个对象
意思是指,是对象能够在当前作用域之外的代码中使用。
 
逸出
当某个不应该发布的对象被发布时,被称为逸出。
 
发布对象的方式:
发布对象最简单的方法是将对象的引用保存到一个公有的静态变量中。
从非私有的方法中返回一个对象的引用,如java web开发中常用的get set方法。
发布一个内部类的实例(内部类实例包含外部类实例的引用)
 
不要在构造过程中使用this引用逸出(只有在构造函数返回时,this引用才应该从线程中逸出)
 
线程封闭
如果在单线程内访问数据,就不需要同步。这种技术称为线程封闭。
 
实现线程封闭的方法:
Ad-hoc线程封闭(了解)
栈封闭(在方法内的局部变量访问对象,熟悉)
ThreadLocal类(常用)
 
ThreadLocal类
这个类能使线程中的某个值与保存值的对象关联起来。该类提供get与set等访问接口或方法,这些方法为每个使用该变量的线程都存有一份独立副本,因此get总是返回当前线程在调用set时设置的最新值。当线程终止后,这些值会作为垃圾回收。
 
不可变对象一定是线程安全的
 
满足以下条件时,对象才是不可变的:
对象创建以后其状态就不可以修改
对象的所有域都是final类型
对象是正确创建的(创建对象时,this引用没有逸出)

java并发编程实战(java concurrency in practice)的更多相关文章

  1. 【Java并发编程实战】----- AQS(四):CLH同步队列

    在[Java并发编程实战]-–"J.U.C":CLH队列锁提过,AQS里面的CLH队列是CLH同步锁的一种变形.其主要从两方面进行了改造:节点的结构与节点等待机制.在结构上引入了头 ...

  2. 【Java并发编程实战】----- AQS(三):阻塞、唤醒:LockSupport

    在上篇博客([Java并发编程实战]----- AQS(二):获取锁.释放锁)中提到,当一个线程加入到CLH队列中时,如果不是头节点是需要判断该节点是否需要挂起:在释放锁后,需要唤醒该线程的继任节点 ...

  3. 【Java并发编程实战】----- AQS(二):获取锁、释放锁

    上篇博客稍微介绍了一下AQS,下面我们来关注下AQS的所获取和锁释放. AQS锁获取 AQS包含如下几个方法: acquire(int arg):以独占模式获取对象,忽略中断. acquireInte ...

  4. 【Java并发编程实战】-----“J.U.C”:CountDownlatch

    上篇博文([Java并发编程实战]-----"J.U.C":CyclicBarrier)LZ介绍了CyclicBarrier.CyclicBarrier所描述的是"允许一 ...

  5. 【Java并发编程实战】-----“J.U.C”:CyclicBarrier

    在上篇博客([Java并发编程实战]-----"J.U.C":Semaphore)中,LZ介绍了Semaphore,下面LZ介绍CyclicBarrier.在JDK API中是这么 ...

  6. 【Java并发编程实战】-----“J.U.C”:ReentrantReadWriteLock

    ReentrantLock实现了标准的互斥操作,也就是说在某一时刻只有有一个线程持有锁.ReentrantLock采用这种独占的保守锁直接,在一定程度上减低了吞吐量.在这种情况下任何的"读/ ...

  7. 【Java并发编程实战】-----“J.U.C”:Semaphore

    信号量Semaphore是一个控制访问多个共享资源的计数器,它本质上是一个"共享锁". Java并发提供了两种加锁模式:共享锁和独占锁.前面LZ介绍的ReentrantLock就是 ...

  8. 【Java并发编程实战】-----“J.U.C”:ReentrantLock之三unlock方法分析

    前篇博客LZ已经分析了ReentrantLock的lock()实现过程,我们了解到lock实现机制有公平锁和非公平锁,两者的主要区别在于公平锁要按照CLH队列等待获取锁,而非公平锁无视CLH队列直接获 ...

  9. 【Java并发编程实战】-----“J.U.C”:ReentrantLock之一简介

    注:由于要介绍ReentrantLock的东西太多了,免得各位客官看累,所以分三篇博客来阐述.本篇博客介绍ReentrantLock基本内容,后两篇博客从源码级别分别阐述ReentrantLock的l ...

  10. 【java并发编程实战】-----线程基本概念

    学习Java并发已经有一个多月了,感觉有些东西学习一会儿了就会忘记,做了一些笔记但是不系统,对于Java并发这么大的"系统",需要自己好好总结.整理才能征服它.希望同仁们一起来学习 ...

随机推荐

  1. jquery通过class验证表单不能为空

    在开发系统时,往往都有某些表单数据为必填项,若用jQuery通过ID去验证,不仅会影响效率,还会有所遗漏,不易于后期维护. 本章将介绍如何利用jQuery,通过为表单配置class进行统一验证.(ID ...

  2. 初刷LeetCode的感受

    自从上个月进入实验室的云安全项目组后,因为要接触到实际的代码,在实验室博士的建议下我们项目组的硕士开始刷LeetCode练习编程能力,保持每周抽空刷几道算法题.虽然刷的不多,到现在一共只刷了不到30题 ...

  3. CLR via C# 读书笔记---常量、字段、方法和参数

    常量 常量是值从不变化的符号.定义常量符号时,它的值必须能在编译时确定.确定后,编译器将唱两只保存在程序集元数据中.使用const关键字声明常量.由于常量值从不变化,所以常量总是被视为类型定义的一部分 ...

  4. Ubuntu上通过nginx部署Django笔记

    Django的部署可以有很多方式,采用nginx+uwsgi的方式是其中比较常见的一种方式.今天在Ubuntu上使用Nginx部署Django服务,虽然不是第一次搞这个了,但是发现还是跳进了好多坑,g ...

  5. mysql编码格式设置

    两个地方能影响到mysql的编码格式 ①.[mysql]下default-character-set=GBK//指的是客户端输入的内容的编码(GBK只是支持中英文)②.[mysqld]下# The d ...

  6. 看 nova-scheduler 如何选择计算节点 - 每天5分钟玩转 OpenStack(27)

    本节重点介绍 nova-scheduler 的调度机制和实现方法:即解决如何选择在哪个计算节点上启动 instance 的问题. 创建 Instance 时,用户会提出资源需求,例如 CPU.内存.磁 ...

  7. 理解 Node.js 里的 process.nextTick()

    有很多人对Node.js里process.nextTick()的用法感到不理解,下面我们就来看一下process.nextTick()到底是什么,该如何使用. Node.js是单线程的,除了系统IO之 ...

  8. mysql 导出select语句结果到excel文件等

    一.导出数据外部 1)mysql连接+将查询结果输出到文件.在命令行中执行(windows的cmd命令行,mac的终端) mysql -hxx -uxx -pxx -e "query sta ...

  9. execve(file, argv, env)参数argv获取字符串个数

    /* Copyright (C) 1999, 2000, 2002, 2003 Free Software Foundation, Inc. This file is part of the GNU ...

  10. Label控件如何根据字符串自定义大小

    一.. this.label_Msg.AutoSize = false;  //设置label空件不能自动大小 二.. 用代码控制label控件的大小 1.根据字符串.label的宽度 计算字符串的面 ...