偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

每天一道面試題-CPU偽共享

開發(fā) 前端
如果要獲取一個(gè)內(nèi)存中的數(shù)據(jù),首先會(huì)從一級緩存中獲取,如果一級緩存中沒有,就會(huì)從二級緩存中獲取,如果二級緩存中沒有,就會(huì)從三級緩存中獲取,如果三級緩存中沒有,就會(huì)從內(nèi)存中獲取。

前言:

了不起:又到了每天一到面試題的時(shí)候了!學(xué)弟,最近學(xué)習(xí)的怎么樣啊 

了不起學(xué)弟:最近學(xué)習(xí)的還不錯(cuò),每天都在學(xué)習(xí),每天都在進(jìn)步! 

了不起:那你最近學(xué)習(xí)的什么呢? 

了不起學(xué)弟:最近在學(xué)習(xí)CPU偽共享,但是不太理解,能不能給我講講呢?

正文:

首先,我們先了解一下CPU的緩存模型。

CPU的緩存分為三層,一級緩存,二級緩存,三級緩存。

如果要獲取一個(gè)內(nèi)存中的數(shù)據(jù),首先會(huì)從一級緩存中獲取,如果一級緩存中沒有,就會(huì)從二級緩存中獲取,如果二級緩存中沒有,就會(huì)從三級緩存中獲取,如果三級緩存中沒有,就會(huì)從內(nèi)存中獲取。

一級緩存是最快的,越到后面就越慢。那CPU的緩存,是由緩存行組成的,每個(gè)緩存行的大小是64字節(jié),也就是說,如果我們要獲取一個(gè)數(shù)據(jù),那么就會(huì)把這個(gè)數(shù)據(jù)所在的內(nèi)存地址,以及這個(gè)數(shù)據(jù)所在的內(nèi)存地址的前后64字節(jié)的數(shù)據(jù),都會(huì)加載到緩存行中。 

聊到這里,我就給大家看看常見的偽共享問題的案例。 

假設(shè)有兩個(gè)線程a和b,同時(shí)有兩個(gè)long類型的變量A和B。兩個(gè)變量都是互相緊挨著的。那線程a要去操作A,就會(huì)把變量A和B一起帶入的緩存行,線程b要去操作變量B,也會(huì)同時(shí)把AB帶入緩存行。此時(shí)如果線程a把A做了修改,再通過BUS總線進(jìn)行了通知,內(nèi)存再做了修改。線程b重新從內(nèi)存獲取變量B,那么此時(shí)這種還需要從內(nèi)存獲取變量,這就是偽共享了。 

偽共享:變量AB毫不相關(guān),但是一旦其中一個(gè)變量被修改,另一個(gè)變量也會(huì)被重新加載。

偽共享的解決方案: 

  1. 使用緩存行填充,也就是說,我們在變量AB之間,加入一些無用的變量,讓AB不在同一個(gè)緩存行中,這樣就不會(huì)出現(xiàn)偽共享的問題了。

舉例:

private static class Padding{
    private volatile long a;
    public volatile long a1,a2,a3,a4,a5,a6,a7;
    private volatile long b;
  }
2.使用@Contened注解在變量上,同時(shí)在jdk8中還需要在jvm啟動(dòng)參數(shù)中加入
-XX:-RestrictContended,jdk8以上的版本就不需要這個(gè)參數(shù)即可,
這樣就可以解決偽共享的問題了。
private static class Padding{
    @Contended
    private volatile long a;
    @Contended
    private volatile long b;
  }

結(jié)尾:

今天就給大家分享了一下關(guān)于CPU偽共享的問題,大家如果對CPU緩存模型那塊還有疑問,可以多查找一下資料,比如MESI緩存一致模型等等。

責(zé)任編輯:武曉燕 來源: Java面試教程
相關(guān)推薦

2024-10-11 17:09:27

2011-05-23 11:27:32

面試題面試java

2018-03-06 15:30:47

Java面試題

2009-08-11 14:59:57

一道面試題C#算法

2009-08-11 10:12:07

C#算法

2023-02-04 18:24:10

SeataJava業(yè)務(wù)

2021-05-31 07:55:44

smartRepeatJavaScript函數(shù)

2017-11-21 12:15:27

數(shù)據(jù)庫面試題SQL

2022-02-08 18:09:20

JS引擎解析器

2022-04-08 07:52:17

CSS面試題HTML

2009-08-11 15:09:44

一道面試題C#算法

2021-03-16 05:44:26

JVM面試題運(yùn)行時(shí)數(shù)據(jù)

2021-10-28 11:40:58

回文鏈表面試題數(shù)據(jù)結(jié)構(gòu)

2015-09-02 14:09:19

面試題程序設(shè)計(jì)

2017-03-10 09:33:16

JavaScript類型

2017-09-13 07:15:10

Python讀寫文件函數(shù)

2021-03-27 10:59:45

JavaScript開發(fā)代碼

2011-03-02 10:58:16

SQL server入門面試題

2011-06-14 09:12:03

JavaScript

2018-02-01 16:26:44

面試題static變量
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號