1. 잠금은 상호 배제와 가시성의 두 가지 주요 기능을 제공합니다. 상호 배제를 사용하면 한 번에 하나의 스레드만 특정 잠금을 보유할 수 있으므로 이 기능을 사용하여 공유 데이터에 대한 조정된 액세스 프로토콜을 구현하여 한 번에 하나의 스레드만 공유 데이터를 사용할 수 있습니다. 가시성은 좀 더 복잡하며 잠금이 해제되기 전에 공유 데이터에 대한 변경 사항이 나중에 잠금을 획득하는 다른 스레드에서 볼 수 있도록 보장해야 합니다. 동기화 메커니즘에서 제공하는 가시성 보장 없이 스레드가 보는 내용은 공유 변수일 수 있습니다. 이전 값이나 일관성 없는 값이 있어 많은 심각한 문제가 발생할 수 있습니다.
2.
Java에서는 멀티 스레드가 데이터를 읽고 쓸 때 데이터 일관성을 보장하기 위해 두 가지 방법을 사용할 수 있습니다.
동기화
예를 들어, 동기화된 키워드를 사용하거나 잠금 개체를 사용하세요.
휘발성
휘발성 키워드를 사용하세요.
휘발성을 한 문장으로 요약하면, 변수를 사용하면 값이 변경될 때 다른 스레드에 최대한 빨리 알릴 수 있습니다.
휘발성에 대한 자세한 설명
먼저 이 현상을 빠르게 인지해야 합니다. 프로그램의 실행 속도를 높이려면 변수 쓰기 작업이 먼저 레지스터나 CPU 캐시에서 수행되고 마지막으로 메모리에 기록됩니다.
이 과정에서 변수의 새 값은 보이지 않습니다. 휘발성의 역할은 그것을 수정하는 것입니다. 변수의 읽기 및 쓰기 작업은 메모리에서 수행되어야 합니다.
휘발성 및 동기화
휘발성의 본질은 레지스터에 있는 현재 변수의 값이 불확실하고 주 메모리에서 읽어와야 하는 jvm은 현재 변수를 잠급니다.
휘발성입니다.
Volatile은 변수의 수정 가시성만 구현할 수 있고 원자적 특성은 없지만, 동기화는 변수의 수정 가시성과 원자성을 보장합니다. .
휘발성은 스레드 차단을 유발하지 않지만 동기화됨은 스레드 차단을 일으킬 수 있습니다.
휘발성으로 표시된 변수는 컴파일러에 의해 최적화되지 않지만 동기화된 것으로 표시된 변수는 컴파일러에 의해 최적화될 수 있습니다.
3 따라서 단순 유형 변수뿐만 아니라 휘발성 키워드를 사용할 때는 주의해야 합니다. 휘발성 수정을 사용하면 이 변수에 대한 모든 연산은 변수의 값이 n=n+와 같이 이전 변수에 의해 결정되는 경우 원래 연산이 됩니다. 1, n++ 등의 경우 휘발성 키워드는 변수 값이 자신과 동일한 경우에만 유효하지 않습니다. 예를 들어 n = m + 1과 같이 변수에 대한 작업은 원자 수준에서 수행됩니다. , 이것이 원래 수준입니다. 따라서 휘발성 키를 사용할 때는 주의해야 합니다. 확실하지 않은 경우 휘발성 대신 동기화를 사용할 수 있습니다.
요약: 휘발성의 본질은 레지스터의 현재 변수 값이 불확실하며 메인 메모리에서 읽어야 함을 JVM에 알리는 것입니다. 동기화 효과 중 일부는 달성할 수 있지만 n=n+1, n++ 등의 경우 휘발성 키워드는 유효하지 않으며 동기화와 동일한 스레드 동기화 효과를 얻을 수 없습니다.