목차
1. 프로그램을 통해 현상을 살펴보세요
2. 이런 현상은 왜 발생하나요(JMM 모델)?
는 변경되지 않았으므로 스레드 1은 무한 루프
Java java지도 시간 Java 동시 프로그래밍의 휘발성 및 JMM 다중 스레드 메모리 모델 분석 예

Java 동시 프로그래밍의 휘발성 및 JMM 다중 스레드 메모리 모델 분석 예

May 27, 2023 am 08:58 AM
java volatile jmm

1. 프로그램을 통해 현상을 살펴보세요

Java 멀티 스레드 캐시 모델을 설명하기 전에 먼저 다음 코드를 살펴보겠습니다. 이 코드의 논리는 매우 간단합니다. 메인 스레드는 두 개의 하위 스레드, 즉 하나의 스레드 1과 하나의 스레드 2를 시작합니다. 스레드 1이 먼저 실행되고 스레드 2는 2초 동안 휴면 상태가 된 후 실행됩니다. 두 스레드는 초기 값이 false인 공유 변수 shareFlag를 사용합니다. shareFlag가 항상 false이면 스레드 1은 항상 무한 루프에 있으므로 스레드 2에서는 shareFlag를 true로 설정합니다.

public class VolatileTest {
  public static boolean shareFlag = false;
  public static void main(String[] args) throws InterruptedException {
    new Thread(() -> {
      System.out.print("开始执行线程1 =>");
      while (!shareFlag){  //shareFlag = false则一直死循环
        //System.out.println("shareFlag=" + shareFlag);
      }
      System.out.print("线程1执行完成 =>");
    }).start();
    Thread.sleep(2000);
    new Thread(() -> {
      System.out.print("开始执行线程2 =>");
      shareFlag = true;
      System.out.print("线程2执行完成 =>");
    }).start();
  }
}

JMM 스레드 모델을 배우지 않았다면 아마도 위 코드를 읽은 후 출력 결과가 다음과 같기를 바랍니다.

스레드 1 실행 시작 => 스레드 2 실행 시작 => 스레드 2 실행 완료 = > 스레드 1 실행 완료 =>

아래 그림과 같이 일반 사람들은 이 코드를 이해합니다. 먼저 스레드 1이 실행되어 루프에 들어가고 스레드 2가 shareFlag=true로 수정되고 스레드 1이 루프에서 빠져나옵니다. 따라서 루프를 벗어나는 스레드 1은 "Thread 1 실행 완료 =>"를 인쇄하지만 작성자의 실험 후에는 **"Thread 1 실행 완료 =>"가 인쇄되지 않고 스레드 1은 루프를 벗어나지 않습니다. 무한 루프**. 이것이 왜?

Java 동시 프로그래밍의 휘발성 및 JMM 다중 스레드 메모리 모델 분석 예

2. 이런 현상은 왜 발생하나요(JMM 모델)?

위에서 언급한 문제를 설명하려면 JMM(Java Memory Model) Java 메모리 모델을 배워야 합니다. Java 멀티스레드 메모리 모델이라고 부르는 것이 더 정확할 것 같습니다.

Java 동시 프로그래밍의 휘발성 및 JMM 다중 스레드 메모리 모델 분석 예

  • 먼저 JMM에서는 각 스레드가 자체 작업 메모리를 가지고 있습니다. 프로그램이 시작되면 스레드는 공유 변수를 자체 작업 메모리에 로드(읽기 및 로드)하고, 스레드의 작업 메모리 메모리 변수에 로드합니다. 메인 메모리에 있는 공유 변수의 복사본입니다. 즉, 현재 메모리에는 shareFlag의 복사본이 3개 있고 그 값은 모두 false와 같습니다.

  • 스레드 2가 shareFlag=true를 실행할 때 작업 메모리 복사본을 shareFlag=true로 수정하는 동시에 복사본의 값을 다시(저장 및 쓰기)에 씁니다. 메인 메모리에. shareFlag=true的时候将其工作内存副本修改为shareFlag=true,同时将副本的值同步写回(store&write)到主内存中。

  • 但是线程1的工作内存中的shareFlag=false

  • 그러나 스레드 1의 작업 메모리에 있는
shareFlag=false

는 변경되지 않았으므로 스레드 1은 무한 루프

에 있었습니다.

3. MESI 캐시 일관성 프로토콜

스레드 2에 의한 공유 변수 수정은 스레드 1에서 인식되지 않으며 이는 위의 실험 결과 및 JMM 모델과 일치합니다. 그렇다면 스레드 1은 공유 변수의 값이 변경되었음을 어떻게 인식할 수 있습니까? 사실 매우 간단합니다. shareFlag 공유 변수에 휘발성 키워드를 추가하기만 하면 됩니다.
    public volatile static boolean shareFlag = false;
  1. 기본 원칙은 다음과 같습니다. 휘발성 키워드를 추가하면 JMM은 다음과 같은 캐시 사용 사양이 포함된 MESI 캐시 일관성 프로토콜을 따르게 됩니다. (

    이해할 수 없는 경우 무시해도 됩니다. 아래에 간단한 언어와 예시가 있습니다. ).

  2. Modified: 현재 캐시 라인의 데이터가 수정(Dirty)되었으며 이때 현재 CPU의 캐시에서만 수정되었음을 나타냅니다. 캐시 라인의 데이터는 데이터와 다릅니다. 다른 캐시에서도 해당 행에 대한 메모리의 데이터와 다릅니다.

  3. Exclusive: 현재 캐시 라인의 데이터가 유효한 데이터이고 다른 CPU의 캐시에 그러한 데이터 라인이 없으며 현재 캐시 라인 데이터가 메모리의 데이터와 동일함을 나타냅니다. .

  4. Shared: 이 데이터 라인이 여러 CPU의 캐시에 캐시되고 캐시의 데이터가 메모리의 데이터와 일치함을 의미합니다.

  5. InvalidJava 동시 프로그래밍의 휘발성 및 JMM 다중 스레드 메모리 모델 분석 예: 이는 다음을 의미합니다. 현재 Cache 라인의 데이터가 유효하지 않다는 것을 ;

    • 위의 캐시 사용 사양은 너무 복잡할 수 있습니다. 간단히 말해서
    • 스레드 2가 shareFlag를 수정하면(수정 참조) 공유 변수 shareFlag를 수정한 버스,
    • Thread 1은 버스를 모니터링합니다. 공유 변수 shareFlag가 수정되었음을 알게 되면 작업 메모리에서 shareFlag 복사본을 삭제하여 유효하지 않게 만듭니다.
    🎜🎜스레드 1이 shareFlag를 다시 사용해야 하고 작업 메모리에 shareFlag 변수의 복사본이 없음을 발견하면 주 메모리에서 다시 로드(읽기 및 로드)됩니다🎜🎜🎜

    위 내용은 Java 동시 프로그래밍의 휘발성 및 JMM 다중 스레드 메모리 모델 분석 예의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Stock Market GPT

Stock Market GPT

더 현명한 결정을 위한 AI 기반 투자 연구

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제

Java에서 파일을 만드는 방법 Java에서 파일을 만드는 방법 Sep 21, 2025 am 03:54 AM

usefile.createnewfile () to reatefileonlyifitdoesn'texist, 피하기;

폴더를 찾는 곳 폴더를 찾는 곳 Sep 20, 2025 am 07:57 AM

가장 직접적인 방법은 일반적으로 데스크탑, 문서, 다운로드 등과 같은 폴더에서 저장 위치를 ​​기억하는 것입니다. 찾을 수없는 경우 시스템 검색 기능을 사용할 수 있습니다. "누락"파일은 주로 저장 경로의 감수, 이름 메모리 편차, 파일 숨기기 또는 클라우드 동기화와 같은 문제로 인한 것입니다. 효율적인 관리 제안 : 프로젝트, 시간 및 유형별로 분류하고, 빠른 액세스, 정기적으로 깨끗하고 보관하고, 이름 지정을 표준화합니다. Windows 검색 및 파일 탐색기 및 작업 표시 줄을 통해 검색하고 검색하는 반면 MacOS는 Finder 및 Spotlight에 의존하며, 이는 더 똑똑하고 효율적입니다. 도구를 마스터 링하고 좋은 습관을 개발하는 것이 핵심입니다.

Java의 ClassPath에 JAR 파일을 추가하는 방법은 무엇입니까? Java의 ClassPath에 JAR 파일을 추가하는 방법은 무엇입니까? Sep 21, 2025 am 05:09 AM

-CP 매개 변수를 사용하여 JVM이 ClassPath에 추가하여 JAVA -Clibrary.jarcom.example.Main과 같은 내부 클래스 및 리소스를로드 할 수 있으며, 이는 세미콜론 또는 콜론으로 분리 된 여러 항아리를 지원하며 클래스 경로 환경 변수 또는 Manifest.MF를 통해 구성 할 수 있습니다.

Java에서 인터페이스를 구현하는 방법은 무엇입니까? Java에서 인터페이스를 구현하는 방법은 무엇입니까? Sep 18, 2025 am 05:31 AM

Amplements 키워드를 사용하여 인터페이스를 구현하십시오. 이 클래스는 인터페이스에서 모든 메소드의 특정 구현을 제공해야합니다. 여러 인터페이스를 지원하고 메소드가 공개되도록 쉼표로 분리됩니다. Java 8 이후의 기본 및 정적 메소드는 다시 작성할 필요가 없습니다.

Chrome 은이 페이지를로드 할 수 없습니다 Chrome 은이 페이지를로드 할 수 없습니다 Sep 20, 2025 am 03:51 AM

먼저 네트워크 연결이 정상인지 확인하십시오. 다른 웹 사이트를 열 수 없으면 문제는 네트워크에 있습니다. 1. 브라우저 캐시 및 쿠키를 지우고 크롬 설정을 입력하고 브라우징 데이터를 선택하십시오. 2. 확장을 닫으면 Scarless 모드를 사용하여 플러그인 충돌로 인한 것인지 테스트 할 수 있습니다. 3. 네트워크 연결이 가로 채지 않도록 프록시 또는 VPN 설정을 점검하고 닫습니다. 4. 크롬 네트워크 설정을 재설정하고 기본 구성을 복원합니다. 5. 호환성 문제를 해결하기 위해 Chrome을 최신 버전으로 업데이트하거나 다시 설치합니다. 6. 다른 브라우저를 사용하여 비교하고 테스트하여 문제가 크롬 일지 여부를 확인하십시오. err_connection_timed_out 또는 err_ssl_protocol_er와 같은 오류 프롬프트에 따르면

자바 제네릭 및 와일드 이해 자바 제네릭 및 와일드 이해 Sep 20, 2025 am 01:58 AM

javagenericsprovidecompile-timetypesafetyandeliminatecastingtypeparametersonclasses, interfaces, methods; wildcards (?,? extendStype,? supertype) handlUnknowntypeswithflexible.1.useUnunUnunUndwildCardWhentyPeiLISIRVENTERREATHERNEATHEATHEATHEATHEATHEATHEATHEATHEATHEARVENTOUBERDERRELOUNTERRELONTERREATHEARBERBERBENTECASTS;

Python은 문자열을 DateTime 예로 변환합니다 Python은 문자열을 DateTime 예로 변환합니다 Sep 18, 2025 am 02:34 AM

DateTime.strpTime () 메소드를 사용하여 문자열을 DateTime 객체로 변환하면 Formatter와 String이 정확히 일치하도록해야합니다. 2. 일반적인 형성자는 %y (4 비트 연도), %m (월), %d (일), %h (시간), %m (분), %s (초) 등; 3. am/pm에서 시간에 %i 및 %p를 사용하고 datetime.fromisoformat ()를 ISO 형식으로 직접 사용하십시오. 4. 형식이 일치하지 않으면 ValueError가 올라갑니다. DateUtil.parser.parse ()를 사용하여 여러 형식을 처리 할 때 자동으로 식별하는 것이 좋습니다. 이러한 방법을 올바르게 사용하면 DateTime 객체에 문자열을 효율적으로 완료 할 수 있습니다.

실시간 시스템에 결정적인 응답 보장이 필요한 이유는 무엇입니까? 실시간 시스템에 결정적인 응답 보장이 필요한 이유는 무엇입니까? Sep 22, 2025 pm 04:03 PM

실시간 시스템은 결과 전달 시간에 달려 있기 때문에 결정 론적 응답이 필요합니다. 하드 실시간 시스템은 엄격한 마감일이 필요하고, 누락 된 경우, 부드러운 실시간은 때때로 지연을 허용합니다. 스케줄링, 인터럽트, 캐시, 메모리 관리 등과 같은 비 결정적 요인 등은 타이밍에 영향을 미칩니다. 건설 계획에는 RTO, WCET 분석, 리소스 관리, 하드웨어 최적화 및 엄격한 테스트 선택이 포함됩니다.

See all articles