并发

杂乱无章

  1. 站在程序性能的角度看,在单处理器的机器上使用并发不会有对改善性能有什么影响,除非一个任务可能阻塞。
  2. volatile(易变性):long和double是分开的两个32位操作,所以是非原子性的,可能会出现在操作一部分后系统出现上下文切换,造成读写数据错误。使用volatile定义long和double,保证其原子性。(64位系统中long和double也是非原子性的,详见java虚语言规范)
  3. volatile关键字确保属性在整个应用中的可见性。如果声明一个属性为volatile,则一旦对这个属性进行写入操作,所有的读取都能立即发现它的变化。即使涉及到处理器缓存时,它也是正确的-volatile修饰的属性会立即写入内存中(不放在处理机缓存中),而读取是从内存中获取。
  4. It’s important to understand that atomicity and volatility are distinct concepts. An atomic operation on a non-volatile field will not necessarily be flushed to main memory, and so another task that reads that field will not necessarily see the new value. If multiple tasks are accessing a field, that field should be volatile; otherwise, the field should only be accessed via synchronization. Synchronization also causes flushing to main memory, so if a field is completely guarded by synchronized methods or blocks, it is not necessary to make it volatile.(读着就觉得牛逼)
    Any writes that a task makes will be visible to that task, so you don’t need to make a field volatile if it is only seen within a task.
    volatile doesn’t work when the value of a field depends on its previous value (such as incrementing a counter), nor does it work on fields whose values are constrained by the values of other fields, such as the lower and upper bound of a Range class which must obey the constraint lower <= upper.

线程状态

  1. New:当线程创建时,线程在这个状态停留片刻时间。它开辟所需要的所有系统资源和进行初始化。在这个时刻,这个线程有资格去获取CPU时间。接下来调度器会将这个线程转换到可运行状态或阻塞状态。
  2. Runnable:这意味着当此线程获取到CPU分片机制所提供的CPU执行周期时,可以运行。所以此线程在任何时刻可能运行也可能不运行,但是当时间调度机制安排它运行时,没有其他地方阻挡它运行。它没有处于死亡或者阻塞状态。
  3. Blocked:线程可以运行,但是某些地方阻挡了其运行。当一个线程处于阻塞状态,线程调度器会直接跳过它,并且不会给它CPU时间。如果没有再次进入可运行状态,它不会进行任何其他操作。
  4. Dead:当一个线程处于死亡或者终结状态时,它将不会再被调度执行,也将不再会获取CPU时间。它的任务结束了,也不会再次运行了。一个任务死亡的一种方式是从run()方法中返回,但是一个任务线程也可以被中断。

造成阻塞的几种情况

  1. 通过调用sleep(milliseconds)方法使任务进入睡眠状态,在这种状况下,在指定的时间内,它不会运行。
  2. 通过wait()方法挂起了线程的执行。当这个线程收到notify()或者notifyAll()信息(or the equivalent signal( ) or signalAll( ) for the Java SE5 java.util.concurrent library tools),它将再次可以运行。
  3. 任务在等待I/O完成。
  4. 任务在尝试调用另一个对象上的synchronized方法,而由于那个对象的锁已被其他任务获取到,这个任务不能获取那个对象上的锁。

Java线程中,异常用来做终止线程

  1. sleep(milliseconds)造成的阻塞可通过interrupt()方法中断,I/O阻塞和synchronized造成的阻塞不可以通过interrupt()中断。
  2. 可以通过关闭造成任务阻塞的资源(io流等)来终止线程。
  3. 由ReentrantLocks造成阻塞的任务可以通过interrupt()方法中断。

杂乱无章

  1. Sleep()与yield()都不释放锁,wait()释放锁。
  2. wait( ), notify( )和notifyAll( )方法会操作锁(sleep()不操作锁)。这三个方法只能在同步方法或者同步代码块中调用(在非同步方法和同步代码块中运行时会抛出异常),而sleep()可以在非同步方法和代码块中调用。
  3. java.util.concurrent.BlockingQueue:同步队列,一次只允许一个任务从队列中获取元素或者向队列中插入元素。
    当队列是空的,而一个任务尝试去获取队列中的元素时,这个任务将被挂起;当有元素可以访问时挂起的任务再继续执行。
    相比于wait()和notifyAll(),同步队列更加简洁和可靠。

发生死锁的四个条件

  1. 互相排斥。至少一个资源是所有任务不共享的。
  2. 至少一个任务已经持有一个资源,并且等待获取正在被另一个任务所持有的资源。
  3. 一个资源不能提前从一个任务中拿走。多个任务只能以正常的事件方式释放资源。
  4. 循环等待。

杂乱无章

  1. DelayQueue:is an unbounded BlockingQueue of objects that implement the Delayed interface.继承了同步队列,用来放实现了Delaye接口的元素 。放置的所有元素按照延迟时间排序,延迟时间短的元素先执行。
  2. PriorityBlockingQueue:is basically a priority queue that has blocking retrieval operations.是一个有同步访问操作的优先级队列。队列中元素实现Comparable接口,用来比较优先级。
  3. Semaphore:一般的锁(concurrent.locks锁或者内置的synchronized锁)一次只允许一个任务来访问资源。一个计数信号量(semaphore)允许n个任务同时访问资源。
  4. Exchanger:是在两个任务中交换对象的同步屏障。当一个任务进入同步屏障时,它持有一个对象,当它离开时,它持有的是之前被另一个任务所持有的对象,而另一个任务持有它进入同步屏障时所持有的那个对象。
  5. CopyOnWriteArrayList:List的子类,当遍历元素的时候允许remove(),不会抛出ConcurrentModificationException异常。

免锁容器

  1. 实现机制
    当读写和修改同时发生时,用户只能访问到修改完毕的结果。修改发生在原本数据结构的一部分中,这部分保存了这个数据结构的一个分离的副本。当修改进行中时,这个副本是不可见的。只有当修改完成时,被修改的这部分副本的数据结构原子的替换掉原来的数据结构。接下来用户看到的就是修改过后的数据结构。CopyOnWriteArrayList就是通过这个机制实现(此list在多个任务遍历修改时不会抛ConcurrentModificationException)。
  2. Vector and Hashtable had many synchronized methods.
  3. CopyOnWriteArraySet uses CopyOnWriteArrayList to achieve its lock-free behavior.
  4. ConcurrentHashMap and ConcurrentLinkedQueue use similar techniques to allow concurrent reads and writes, but only portions of the container are copied and modified rather than the entire container. However, readers will still not see any modifications before they are complete. ConcurrentHashMap doesn’t throw ConcurrentModificationExceptions.
  5. ConcurrentHashMap and ConcurrentLinkedQueue use similar techniques to allow concurrent reads and writes, but only portions of the container are copied and modified rather than the entire container. However, readers will still not see any modifications before they are complete. ConcurrentHashMap doesn’t throw ConcurrentModificationExceptions.
  6. 乐观锁:
  7. ReadWriteLocks(读写锁):当多个任务对一个数据结构读的比较频繁,但是相对来说写的比较不频繁时,可以用读写锁来进行优化。
    The ReadWriteLock allows you to have many readers at one time as long as no one is attempting to write. If the write lock is held, then no readers are allowed until the write lock is released.
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,884评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,755评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,369评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,799评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,910评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,096评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,159评论 3 411
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,917评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,360评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,673评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,814评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,509评论 4 334
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,156评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,882评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,123评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,641评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,728评论 2 351