> 백엔드 개발 > C++ > C 11 멀티스레딩에서 '휘발성'이 여전히 관련이 있나요?

C 11 멀티스레딩에서 '휘발성'이 여전히 관련이 있나요?

Susan Sarandon
풀어 주다: 2024-10-29 03:18:02
원래의
883명이 탐색했습니다.

Is `volatile` Still Relevant in C  11 Multithreading?

C 11의 휘발성 변수

C 11 표준에 멀티 스레드 머신 모델이 도입되면서 휘발성 변수의 동작에 대한 의문이 제기됩니다. 동시 환경에서 정의되지 않은 동작을 초래할 수 있는 최적화를 방지하기 위해 전통적으로 사용되었던 변수입니다.

C 98/03에서는 메모리 모델에서 멀티스레딩을 인식하지 못하여 컴파일러가 최적화할 수 있음을 의미했습니다. 휘발성 변수를 읽은 후 변수의 값이 변경되기를 기다리는 끝없는 while 루프의 악명 높은 예로 이어집니다.

그러나 C 11 메모리 모델은 변수에 대한 동시 액세스 가능성을 인정합니다. 이는 휘발성이 이제 더 이상 사용되지 않는다는 뜻인가요?

컴파일러 최적화 및 정의되지 않은 동작

답은 C 11 메모리 모델의 미묘한 특성에 있습니다. 멀티스레딩을 인식하지만 적절한 동기화 없이 변수에 액세스할 때 정의되지 않은 동작이 발생할 가능성을 제거하지는 않습니다. 멀티 스레드 환경에서도 공유 변수에 대한 비원자적 액세스는 정의되지 않은 상태로 유지됩니다.

휘발성 int x;
void func() {
x = 0;
while (x = = 0) {}
}

따라서 예시 코드에서 컴파일러는 여전히 while 루프에서 x 읽기를 자유롭게 최적화하여 정의되지 않은 동작을 발생시킵니다. 휘발성은 스레딩 동작이 아닌 메모리 액세스에만 영향을 미칩니다.

메모리 장벽 및 스레딩 무결성

스레딩 무결성에는 한 스레드에서 다른 스레드로의 쓰기 가시성을 보장하기 위한 적절한 동기화 메커니즘이 필요합니다. . C 11 메모리 모델은 쓰기가 다른 스레드에 표시되는 시기와 방법을 구체적으로 정의합니다. 휘발성은 이 요구 사항을 해결하지 않습니다.

휘발성은 컴파일러가 변수에서 메모리 읽기를 최적화할 수 없음을 보장하지만 스레드 가시성에 대한 어떠한 보장도 제공하지 않습니다. 잠금 또는 원자적 작업과 같은 동기화 구성에 의해 발행된 메모리 장벽은 쓰기가 코어 간에 동기화되도록 보장하는 데 필요합니다.

결론

C 11에서는 휘발성이 여전히 관련성을 유지합니다. 잘못된 메모리 액세스로 이어질 수 있는 최적화를 방지합니다. 그러나 다중 스레드 프로그래밍에는 충분하지 않습니다. 동시 환경에서 스레드 무결성과 정의된 동작을 보장하려면 적절한 동기화 메커니즘이 여전히 필요합니다.

위 내용은 C 11 멀티스레딩에서 '휘발성'이 여전히 관련이 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿