자바 병발 메커니즘 하부 실현 원리-volatile

장절 목록
  • volatile 의 실현 원리 와 응용
  • 1.volatile 의 실현 원리 와 응용
    자바 source code->자바 class->JVM->어 셈 블 리 명령->cpu 가 자바 에서 사용 하 는 병행 체 제 는 JVM 실현 과 cpu 명령 에 의존 합 니 다.
    1.1 volatile 응용
    volatile-가시 성 확보
    volatile      synchronized,                "   "。
         :
                ,                。
    

    volatile-실행 원가 가 낮다
    volatile               。
        ,volatile       synchronized 。
    

    volatile 은 어떻게 가시 성 을 보증 합 니까
    class A{
       private volatile Singleton instance ;
       public A(){
            instance = new Singleton();
       }
    }
    

    어 셈 블 리 코드 로 전환 합 니 다.다음 과 같 습 니 다.movb,lock add 1 위 에서 volatile 공유 변수 인 스 턴 스 를 작성 할 때 두 번 째 어 셈 블 리 코드 가 더 나 옵 니 다.Lock 접두사 명령 은 다 중 핵 처리 장치 에서 두 가지 일 을 일 으 킬 수 있 습 니 다.
    4
  • 현재 프로세서 캐 시 줄 의 데 이 터 를 시스템 메모리 로 기록 합 니 다(작업 메모 리 를 주 메모리 에 기록 합 니 다)
  • 4.567917.이 쓰기 동작 은 다른 cpu 에 이 메모리 주 소 를 캐 시 한 데이터 가 잘못 되 었 습 니 다
    메모:다 중 프로세서 에서 각 프로세서 캐 시가 일치 하도록 캐 시 일치 성 프로 토 콜 캐 시 일치 성 프로 토 콜 을 실현 합 니 다
                                     
     ,                        ,       
                ,                    ,
                          。
    

    volatile 두 가지 실현 원칙
  • Lock 접두사 명령 은 프로세서 캐 시 를 메모리 에 다시 기록 합 니 다
  • 1.   +        
    2.    +       
    

    4
  • 한 프로세서 의 캐 시 를 메 인 메모리 에 다시 쓰 면 다른 캐 시 를 가 져 올 수 있 습 니 다.이 메 인 메모리 공유 변수의 프로세서 캐 시 는 유효 하지 않 습 니 다
  •                                  
     ,                        ,       
                ,                    ,
                          。
    

    좋은 웹페이지 즐겨찾기