C# 람다 표현식 및 foreach
루프 스레드 안전성
이 문서에서는 C# 버전 간의 차이점에 중점을 두고 C# 람다 식 내의 foreach
루프 내에서 변수에 액세스할 때의 스레드 안전성을 조사합니다.
C# 5 이전 동작
C# 5 이전 버전에서는 다중 스레드 컨텍스트(예: foreach
생성자 내)에서 사용되는 람다 식 내의 Thread
루프 외부에 선언된 변수에 직접 액세스하는 것이 안전하지 않습니다. 이는 foreach
루프의 반복자 변수가 모든 반복에서 공유되기 때문입니다. 결과적으로 여러 스레드가 동일한 변수에 액세스하고 수정하여 예측할 수 없고 잘못된 결과를 초래할 수 있습니다. 경쟁 상황이 발생할 가능성이 높습니다.
C# 5 이상
C# 5부터 컴파일러가 foreach
루프 내에서 반복기를 처리하면 스레드 안전성이 크게 향상됩니다. 이제 컴파일러는 각 반복마다 반복자 변수의 새 인스턴스를 효과적으로 생성합니다. 즉, 각 람다 식이 변수의 고유한 복사본을 캡처하여 경쟁 조건의 위험을 제거합니다. 따라서 C# 5 이상 버전에서는 두 가지 접근 방식(루프 외부 또는 내부에 선언된 단일 반복기 변수 사용)이 일반적으로 스레드로부터 안전한 것으로 간주됩니다.
예시(C#5 이전의 안전하지 않은 동작)
다음 코드 조각은 C#5 이전 버전의 안전하지 않은 동작을 강조합니다.
<code class="language-csharp">static void Main() { int[] data = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 }; foreach (int i in data) { new Thread(() => Console.WriteLine(i)).Start(); } Console.ReadLine(); }</code>
이 코드를 실행하면 i
값이 순차적으로 올바르지 않은 출력이 생성되어 경쟁 조건을 나타낼 수 있습니다. 각 스레드는 동일한 i
변수를 캡처하며 해당 값은 스레드가 람다 식을 실행할 때까지 변경될 수 있습니다.
결론
이전 C# 버전에서는 스레드 안전성을 보장하기 위해 람다 식 내의 foreach
루프에서 반복기 변수를 주의 깊게 처리해야 했지만 C# 5 이상 버전에서는 컴파일러 최적화를 통해 이 문제를 완화합니다. 그러나 특히 C# 버전에 관계없이 람다 식 내에서 공유 리소스를 처리할 때 잠재적인 동시성 문제에 유의하는 것이 좋습니다. 각 반복 내에서 지역 변수를 사용하는 것은 명확성과 유지 관리 가능성을 위한 모범 사례입니다.
위 내용은 C# 람다 식 내 Foreach 루프의 변수에 액세스하면 스레드로부터 안전합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!