总结-1

JVM/GC

1、内存模型:为了屏蔽掉各种硬件和操作系统的内存差异,达到跨平台的内存访问效果。JLS(Java语言规范)定义了一个统一的内存管理模型JMM(Java Memory Model)Java内存模型分为主内存,和工作内存。主内存是所有的线程所共享的,工作内存是每个线程私有的。工作内存中缓存了被该线程使用到的变量的主内存副本拷贝。线程对变量的所有操作(读取、赋值),都必须在工作内存中进行,而不能直接读写主内存中的变量。

运行时数据区:堆,方法区,jvm栈,本地方法栈,程序计数器,其中堆和方法区是线程共享的。

2、volatile保证可见性:将当前处理器缓存行的数据会立即写回到主内存,写回内存的操作会引起在其他CPU里缓存了该内存地址的数据无效(通过缓存一致性);禁止指令重排序;happens before;不保证原子性(使用场景:对变量的写操作不依赖当前值);

3、GC Root

4、垃圾收集器

新生代:Serial, ParNew, Parallel

老年代:Serial Old, Parallel Old, CMS

关系:ParNew是Serial收集器的多线程版本,除了Serial收集器外,目前只有它能和CMS配合工作。

算法:新生代:复制算法,老年代:标记-整理/标记-清除

CMS:集中在互联网站或B/S系统服务端上的Java

应用组合:响应速度优先:ParNew + CMS

吞吐量优先:Parallel + Parallel Old

G1:并发执行不需要其他收集器配合就能独立管理整个GC堆可预测的停顿:G1除了降低停顿外,还能建立可预测的停顿时间模型,能让使用者明确指定在一个长度为M毫秒的时间片段内,消耗在GC上的时间不得超过N毫秒。

5、频繁Full GC的处理http://blogxin.cn/2015/12/02/FullGC-frequently/

6、GC 日志

7、JVM 工具http://www.hollischuang.com/archives/1561https://my.oschina.net/feichexia/blog/1965758、OOM异常

9、JVM调优https://www.jianshu.com/p/c6a04c88900ahttp://www.importnew.com/22434.html

Concurrent

1、AQS

提供一个实现阻塞锁和类似同步器的框架,依赖于先进先出FIFO的等待队列。这个类的设计初衷是作为大部分同步器的基类,依赖于一个int原子变量(state)来表达状态(资源的占用状态)。

总结:维护一个FIFO的队列来实现同步器。如,当前线程获取资源失败时,需要将线程存放在队列中,后续资源可用时被唤醒。定义了一个int变量(state),来代表资源的状态。如独占锁,0表示资源未被占用,1则表示资源已被占用。本类实现了队列和阻塞操作,子类需要完成获取和释放资源的具体实现,为定义为protected的相关方法。如 tryAcquireacquire流程:tryAcquire 获取锁,失败则调用acquireQueued将当前线程加入队列,再次尝试获取锁,失败则park阻塞当前线程

2、CAS AtomicStampedReference

Unsafe://需要更新的对象obj,obj中该field的偏移量,该field的期望值,更新值(如果field的当前值等于期望值expect,则将field值更新未update)compareAndSwapObject(Object obj, long offset, Object expect, Object update);//这是一个有序或者有延迟的putIntVolatile方法,并且不保证值的改变被其他线程立即看到。//只有在field被volatile修饰并且期望被意外修改的时候使用才有用。putOrderedInt(Object obj, long offset, int expect)

AtomicStampedReference:

3、ConcurrentHashMap

用分离锁实现多个线程间的更深层次的共享访问。

用 HashEntery 对象的不变性来降低执行读操作的线程在遍历链表期间对加锁的需求。

通过对同一个 Volatile 变量的写 / 读访问,协调不同线程间读 / 写操作的内存可见性。

4、ReentrantLock Condition synchronized

独占锁,共享锁,公平锁,非公平锁

生产者/消费者:final Lock lock = new ReentrantLock();

final Condition notFull = lock.newCondition(); 

final Condition notEmpty = lock.newCondition(); 

notFull.singal(), notFull.await()

5、ThreadPool BlockQueue

//核心线程数,最大线程数,超出corePoolSize时线程存活时间,时间单位,队列,线程工厂,饱和策略

public ThreadPoolExecutor(int corePoolSize,int maximumPoolSize,long keepAliveTime,TimeUnit unit,BlockingQueue workQueue,ThreadFactory threadFactory,RejectedExecutionHandler handler)

execute:

活动线程数 < corePoolSize,直接创建新的线程;

活动线程数 > corePoolSize,加到任务队列当中;

当队列已满且活动线程 < maximumPoolSize,创建新线程至最大线程数,否则拒绝任务

BlockQueue使用场景

如何合理的估算线程池的大小,防止内存耗尽

6、ExecutorService,Callable,Future

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,546评论 6 507
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,224评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,911评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,737评论 1 294
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,753评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,598评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,338评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,249评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,696评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,888评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,013评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,731评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,348评论 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,929评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,048评论 1 270
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,203评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,960评论 2 355

推荐阅读更多精彩内容