java面试-Java并发编程(二)——重排序
當(dāng)我們寫一個(gè)單線程程序時(shí),總以為計(jì)算機(jī)會(huì)一行行地運(yùn)行代碼,然而事實(shí)并非如此。
什么是重排序?
重排序指的是編譯器、處理器在不改變程序執(zhí)行結(jié)果的前提下,重新排列指令的執(zhí)行順序,以達(dá)到最佳的運(yùn)行效率。
重排序分類
重排序分為:編譯器重排序 和 處理器重排序。
數(shù)據(jù)依賴
編譯器和處理器并不會(huì)隨意的改變指令的執(zhí)行順序,因?yàn)橛行┲噶钪g是有依賴關(guān)系的,若改變了他們的執(zhí)行順序,就會(huì)出現(xiàn)錯(cuò)誤的結(jié)果。?
因此,編譯器和處理器只會(huì)對(duì)沒有依賴關(guān)系的指令進(jìn)行重排序。
數(shù)據(jù)依賴:若相鄰的兩條指令訪問(wèn)同一個(gè)變量,并且其中有一條指令執(zhí)行寫操作,那么這樣的兩條指令之間存在數(shù)據(jù)依賴。對(duì)于有數(shù)據(jù)依賴關(guān)系的指令,不會(huì)發(fā)生重排序。
數(shù)據(jù)依賴關(guān)系總結(jié)一下為以下三種情況:
| 讀后寫 | a=b;b=1; |
| 寫后寫 | a=1;a=2; |
| 寫后讀 | a=1;b=a; |
as-if-serial
在單線程開發(fā)中,程序員不需要知道指令是如何重排序的,只要簡(jiǎn)單地認(rèn)為指令是按照順序依次執(zhí)行的即可。這就是as-if-serial的語(yǔ)義,即:貌似是串行的。
總結(jié)
以上是生活随笔為你收集整理的java面试-Java并发编程(二)——重排序的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: C语言 流缓冲 Stream Buffe
- 下一篇: java垃圾回收机制_干货:Java 垃