foreach
루프 및 클로저의 스레드 안전성
루프와 클로저를 사용할 때 foreach
스레드 안전을 보장하려면 신중한 고려가 필요합니다. 설명하는 시나리오에는 클로저에서 Foo 객체에 대한 참조를 처리하는 방법이 다른 두 가지 코드 조각이 있습니다.
첫 번째 조각은 참조를 직접 전달합니다.
<code class="language-c#">foreach (Foo f in ListOfFoo) { Thread thread = new Thread(() => f.DoSomething()); threads.Add(thread); thread.Start(); }</code>
이 접근 방식은 안전하지 않습니다. 동일한 f
참조가 모든 스레드에서 공유되기 때문입니다. 이는 서로 다른 스레드가 동일한 Foo 객체에 액세스하고 수정하여 예측할 수 없는 동작을 초래할 수 있음을 의미합니다.
스레드 안전성을 보장하려면 두 번째 스니펫에 표시된 것처럼 루프 내부에 참조 복사본을 만들어야 합니다.
<code class="language-c#">foreach (Foo f in ListOfFoo) { Foo f2 = f; Thread thread = new Thread(() => f2.DoSomething()); threads.Add(thread); thread.Start(); }</code>
루프 내부에 새로운 f2
변수를 생성함으로써 각 스레드는 Foo 객체에 대한 참조의 자체 복사본을 갖게 됩니다. 이렇게 하면 각 스레드가 고유한 개체에서 작동하여 경쟁 조건과 잠재적인 데이터 손상을 방지할 수 있습니다.
참고: 이 문제는 스레딩에만 국한되지 않습니다. 비동기 작업이나 이벤트 핸들러에서 클로저를 사용할 때도 동일한 문제가 발생하며, 예상치 못한 동작을 방지하고 데이터 무결성을 유지하려면 특별한 주의가 필요합니다.
위 내용은 클로저와 함께 사용하면 foreach 루프가 스레드로부터 안전합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!