안녕하세요.
고전적인 문제일지는 모르겠는데.. 공유 메모리에서 read/write를 하는 다수의 writer thread와 다수의 reader thread가 있다고 할 때 성능을 높일 수 있는 동기화 방법에는 어떤 것들이 있을까요?
단순히 reader와 writer상관없이 하나의 thread만 공유 메모리에 접근하는 방법외에 방법이 있을지 궁금하네요.
감사합니다.
고전이지만, 현재에도 여전한 문제지요. 아직은 아래 레퍼런스에서 제시한 방법론을 벗어나는 솔루션이 없다고 봅니다만.
----http://www.pearsonhighered.com/educator/academic/product/0,,0805300864,00%2Ben-USS_01DBC.html
http://www.amazon.com/dp/0387949429/ref=rdr_ext_tmb
책이 구하기 힘든데 ㅜㅜ 혹시 어떤 솔루션이 있는지 아시면 귀뜸좀..^^
두개의 스레드라고만 생각해도
read-read read-write write-read write-write 인대
코어 자체에서 두개의 코어가 한가지 레지스터에 두가지 행위를 한다는게 read-read경우 빼고 말이 안되는것 같내요.
순서에 상관없다고 했을때 매모리 접근속도보다 훨씬빠르게 두매모리를 물리적으로 동기화 시켜놓으면 read-write,write-read의 경우(buffer이용)까진 될지 몰라도 write-write 로 두개의 코어가 동시에 접근한다는 경우가 말이 안되고요.
결론적으로 write접근이 한개의 쓰레드에서만 이루어 지는 경우 순서에 상관 없는 접근이라고 하였을때 다수의 스레드 접근은 혀용될수 있다고 생각하는대요.
뭐 이제야 스레드에 대해서 공부하는 학생에 입장에서 제대로 알지 못하고 쓴 말이지반 요즘 멀티 스레드를 어떻게 구성해서 프로그래밍을 해야하는지 고민하는 사람으로써 재미있는 주제라고는 생각되서 글을 남깁니다.
크리티컬 섹션을 제외한 부분은 multi-write 되는 걸요.
대부분의 시간이 크리티컬 섹션 외의 곳에서 일어난다면 유의미한 차이가 있을 것 같네요.
텍스트 포맷에 대한 자세한 정보
<code>
<blockcode>
<apache>
<applescript>
<autoconf>
<awk>
<bash>
<c>
<cpp>
<css>
<diff>
<drupal5>
<drupal6>
<gdb>
<html>
<html5>
<java>
<javascript>
<ldif>
<lua>
<make>
<mysql>
<perl>
<perl6>
<php>
<pgsql>
<proftpd>
<python>
<reg>
<spec>
<ruby>
<foo>
[foo]
고전이지만, 현재에도 여전한 문제지요. 아직은 아래
고전이지만, 현재에도 여전한 문제지요.
아직은 아래 레퍼런스에서 제시한 방법론을 벗어나는 솔루션이 없다고 봅니다만.
----
http://www.pearsonhighered.com/educator/academic/product/0,,0805300864,00%2Ben-USS_01DBC.html
http://www.amazon.com/dp/0387949429/ref=rdr_ext_tmb
책이 구하기 힘든데 ㅜㅜ 혹시 어떤 솔루션이 있는지
책이 구하기 힘든데 ㅜㅜ
혹시 어떤 솔루션이 있는지 아시면 귀뜸좀..^^
물리적으로 하나의 메모리에 한가지 행동만 가능하니...
두개의 스레드라고만 생각해도
read-read read-write write-read write-write 인대
코어 자체에서 두개의 코어가 한가지 레지스터에 두가지 행위를 한다는게 read-read경우 빼고 말이 안되는것 같내요.
순서에 상관없다고 했을때 매모리 접근속도보다 훨씬빠르게 두매모리를 물리적으로 동기화 시켜놓으면 read-write,write-read의 경우(buffer이용)까진 될지 몰라도 write-write 로 두개의 코어가 동시에 접근한다는 경우가 말이 안되고요.
결론적으로 write접근이 한개의 쓰레드에서만 이루어 지는 경우 순서에 상관 없는 접근이라고 하였을때 다수의 스레드 접근은 혀용될수 있다고 생각하는대요.
뭐 이제야 스레드에 대해서 공부하는 학생에 입장에서 제대로 알지 못하고 쓴 말이지반 요즘 멀티 스레드를 어떻게 구성해서 프로그래밍을 해야하는지 고민하는 사람으로써 재미있는 주제라고는 생각되서 글을 남깁니다.
크리티컬 섹션을 제외한 부분은 multi-write
크리티컬 섹션을 제외한 부분은 multi-write 되는 걸요.
대부분의 시간이 크리티컬 섹션 외의 곳에서 일어난다면 유의미한 차이가 있을 것 같네요.
댓글 달기