본문 바로가기
  • 저희는 평생 개발할 운명이걸랑요
Tech.log/운영체제

[Thread-safe]

by SpaciousKitchen 2021. 5. 22.

Thread-safe

멀티 스레드 프로그래밍에서 일반적으로 어떤 함수나 변수, 혹은 객체가 여러 스레드로부터 동시에 접근이 이루어져도 프로그램의 실행에 문제가 없음을 뜻한다.

ex)하나의 함수가 한 스레드로부터 호출되어 실행 중일 때, 다른 스레드가 그 함수를 호출하여 동시에 함께 실행되더라도 각 스레드에서의 함수의 수행 결과가 올바로 나오는 것으로 정의한다.

 

 

 

Thread-safe를 지키기 위한 방법

 

1. Re-entrancy

어떤 함수가 한 스레드에 의해 호출되어 실행 중일 때, 다른 스레드가 그 함수를 호출하더라도 그 결과가 각각에게 올바로 주어져야 한다.

 

2. Thread-local storage

공유 자원의 사용을 최대한 줄여 각각의 스레드에서만 접근 가능한 저장소들을 사용함으로써 동시 접근을 막는다.

이 방식은 동기화 방법과 관련되어 있고, 또한 공유상태를 피할 수 없을 때 사용하는 방식이다.

 

3. Mutual exclusion

공유 자원을 꼭 사용해야 할 경우 해당 자원의 접근을 세마포어 등의 락으로 통제한다.

 

4. Atomic operations

공유 자원에 접근할 때 원자 연산을 이용하거나 '원자적'으로 정의된 접근 방법을 사용함으로써 상호 배제를 구현할 수 있다.

 

1) MUTEX를 이용한 동기화 방법

pthread_mutex_lock(&mutx);

... Critical Section

pthread_mutex_unlock(&mutx);

 

2) SEMAPHORES를 이용한 동기화 방법

 

A Thread

state = sem_init(&bin_sem,0,0);

while(number != 0)

wait...

데이터 처리

sem_post(&bin_sem);

 

B Thread

sem_wait(&bin_sem);

데이터 처리

 

통상적으로 Mutual Exclusion(상호배제) 방식을 이용한 Critical Section 처리가 자주 사용되는 편이다.

 

상호배제란, 한 Thread가 자원에 접근할 때 다른 Thread의 접근을 막는 것을 의미한다.

 

 

 

댓글