도와주세요!!
글 수 15,339
2007.07.05 22:12:15 (*.212.137.23)
10361
조금 조심스러워지네요. ^^ 제 글은 순전히 저의 개인적인 생각이므로 참고만 하셨으면 좋겠습니다. ^^
쓰레드보다 프로세스를 나누는 것이 좋다, 또는 반대로 쓰레드가 좋다라고 우열을 비교하고 한 쪽으로만 사용한다는 것은, 저 개인적인 생각입니다만 옳은 코드라고 생각되지 않습니다.
쓰레드를 사용하거나 프로세스를 나누는 것이나 모두 프로그램을 작성하는 방법의 하나이므로 우열을 따지기 보다는 경우에 따라 방법의 장점에 따라 처리하는 것이 좋지 않을까 생각됩니다.
쓰레드는 코딩하기가 쉽다는 장점이 있습니다만 쓰레드간에 공유 영역 사용을 항상 조심해야 하는 단점이 있습니다.
반면에 프로세스는 이전 프로세스의 영향을 생각하지 않고 코드를 독립적으로 작성할 수 있다는 장점이 있는 반면에 그 독립성 때문에 프로세스끼리 자료를 공유하기 어렵다는 점이 단점이 되겠습니다.
그러나 물론 프로그래머에 따라서 자기가 애용하는 방법이 있습니다. 그러나 그것은 아무래도 자신의 경험에 의해서 결정되는 경우가 많지 않을까 생각됩니다. ^^
>^^
>장길석 포럼지기님께서 직접 답글을 주셨네요. 감사드립니다.
>또한, 지난 FALinux 공개 강좌에서 재밌는 강의를 해 주신것도 이 지면을 통해서 감사 드립니다.
>
>제가 인터넷을 통해 자료를 확인해 보면 멀티 프로세스 보다는 멀티 쓰레드의 장점들이 많이 부각되어 있던데요....특별히 멀티 쓰레드를 사용할지..아니면 멀티 프로세스를 사용할지에 대한 객관적 또는 일반적인 판단의 기준이 있을까요..?
>
>다시 한번 자세한 답변에 감사 드립니다.
>
>
>>저도 학습 중이라 제대로 답을 드리지 못할 것 같아 걱정입니다만
>>혹 도움이 될까해서 제가 아는 범위 내에서 말씀을 올립니다.
>>
>>쓰레드는 프로세스 분리와는 달리 메모리를 공유할 수 있습니다.
>>그렇기 때문에 많은 분들이 광역 변수를 이용하여
>>쓰레드끼리 자료를 전송하거나 수신하는 등의 작업을 합니다.
>>사실 이 방법이 가장 간단하기 때문이죠. ^^
>>
>>그러나 문제는 데이터의 신뢰와 동기 맞추기가 쉽지 않다는 점입니다.
>>즉, 한 쪽 쓰레드에서 광역변수에 값을 대입할 때, 다른 쓰레드에서 같은 대입으로
>>변수값이 오염(? ^^;)될 수 있고,
>>또한 변수 값을 수정했을 때, 상대에게 어떻게 알려 주느냐 하는 것이죠.
>>
>>물론 데이터의 신뢰는 세마포어를 이용하고 동기를 맞추기 위해서는
>>계속 변수값을 확인하거나 다른 변수를 또 두는 방법이 있습니다만,
>>필요한 변수가 하나씩 늘면 전체적으로 매우 어지러운 코드가 되기 쉽습니다.
>>
>>처음 코드가 어렵지만 프로그램이 커지더라도 데이터 처리가 상대적으로 커지지 않는
>>IPC 방법을 권하고 싶습니다. 저는 특히 UDS방식을 애용합니다.
>>
>>UDS는 UDP통신을 하듯 자료를 주고 받기 때문에 데이터의 신뢰성과
>>수신한 상대 쪽에서 바로 데이터를 처리할 수 있는 등의 장점이 있습니다.
>>
>>UDS에 대한 자세한 내용은 아래의 링크를 참고해 주세요.
>>
>>http://forum.falinux.com/bbs/view.php?id=lecture2&no=181
>>
>>또한 쓰레드에서는 광역변수 문제가 또 있습니다.
>>C 함수 중에는 광역 변수를 사용하는 함수가 있습니다.
>>쓰레드를 사용하실 때 광역 변수를 사용하는 함수를 사용하시면 이상한 오류를 발생할 수 있습니다.
>>
>>그러므로 간단한 경우라면 쓰레드도 좋습니다만 가급적 프로세스 생성을 권하고 싶습니다.
>>
>>모쪼록 학습하시는데 조그만 도움이되는 글이었으면 좋겠습니다. ^^
>>
>>>안녕하세요 ESP-MMI 보드로 맹렬히 연습하고 있는 비기너 입니다.
>>>
>>>지난번에 질문 드린 내용이 프로세스가 복수 개일때 데이터 공유에 대한 내용이었는데, 그 때 공유메모리를 소개해 주셨었습니다.
>>>
>>>그런데, 제가 프로세스와 쓰레드에 대해 개념이 없어서 질문을 잘못 드린 것이었는데요...
>>>
>>>다시 질문을 드리면, 하나의 프로세스 내에서 두 개의 쓰레드를 실행시킬 때의 데이터 공유에 대한 문제 입니다.
>>>
>>>1. 일단, 한 프로세스 내의 쓰레드는 같은 메모리 공간을 사용한다는 베이스에서, 프로세스 내에서 전역 변수를 잡아서 사용하니 두 개의 쓰레드 사이에 제가 원하는 데이터 전달이 실행이 되었습니다. 단, 전달된 데이터를 읽어서 다음 액션을 취하는 타이밍이 항상 동일하지 않다는 점이 문제라고 생각되는데...이것은 소위 말하는 자원 동기화 라는 것으로 해결되는 것인가요?
>>>
>>>2. 위의 상황에서 처럼 전역 변수로 데이터를 공유하는 것이 바람직한 또는 일반적인 방법인가요?
>>>
>>>3. 자료를 찾아보니(소개해 주신 joinC) 쓰레드 사이의 데이터 교환에 관해서 전통적인 IPC 방법도 소개하고 있던데, 같은 프로세스 내에 존재하는 쓰레드 사이에서 공유메모리를 이용한 데이터 교환이 가능한 것인가요? 그리고 바람직한 것인가요? (아무리봐도 그냥 전역변수 쓰는 것보다는 복잡하다는 생각이 들어서..)
>>>
>>>비가 많이 옵니다. 참 공부하기 좋은 날씨네요...
>>>항상 우문에 현답을 주심에 감사드리니다.
>>
>
쓰레드보다 프로세스를 나누는 것이 좋다, 또는 반대로 쓰레드가 좋다라고 우열을 비교하고 한 쪽으로만 사용한다는 것은, 저 개인적인 생각입니다만 옳은 코드라고 생각되지 않습니다.
쓰레드를 사용하거나 프로세스를 나누는 것이나 모두 프로그램을 작성하는 방법의 하나이므로 우열을 따지기 보다는 경우에 따라 방법의 장점에 따라 처리하는 것이 좋지 않을까 생각됩니다.
쓰레드는 코딩하기가 쉽다는 장점이 있습니다만 쓰레드간에 공유 영역 사용을 항상 조심해야 하는 단점이 있습니다.
반면에 프로세스는 이전 프로세스의 영향을 생각하지 않고 코드를 독립적으로 작성할 수 있다는 장점이 있는 반면에 그 독립성 때문에 프로세스끼리 자료를 공유하기 어렵다는 점이 단점이 되겠습니다.
그러나 물론 프로그래머에 따라서 자기가 애용하는 방법이 있습니다. 그러나 그것은 아무래도 자신의 경험에 의해서 결정되는 경우가 많지 않을까 생각됩니다. ^^
>^^
>장길석 포럼지기님께서 직접 답글을 주셨네요. 감사드립니다.
>또한, 지난 FALinux 공개 강좌에서 재밌는 강의를 해 주신것도 이 지면을 통해서 감사 드립니다.
>
>제가 인터넷을 통해 자료를 확인해 보면 멀티 프로세스 보다는 멀티 쓰레드의 장점들이 많이 부각되어 있던데요....특별히 멀티 쓰레드를 사용할지..아니면 멀티 프로세스를 사용할지에 대한 객관적 또는 일반적인 판단의 기준이 있을까요..?
>
>다시 한번 자세한 답변에 감사 드립니다.
>
>
>>저도 학습 중이라 제대로 답을 드리지 못할 것 같아 걱정입니다만
>>혹 도움이 될까해서 제가 아는 범위 내에서 말씀을 올립니다.
>>
>>쓰레드는 프로세스 분리와는 달리 메모리를 공유할 수 있습니다.
>>그렇기 때문에 많은 분들이 광역 변수를 이용하여
>>쓰레드끼리 자료를 전송하거나 수신하는 등의 작업을 합니다.
>>사실 이 방법이 가장 간단하기 때문이죠. ^^
>>
>>그러나 문제는 데이터의 신뢰와 동기 맞추기가 쉽지 않다는 점입니다.
>>즉, 한 쪽 쓰레드에서 광역변수에 값을 대입할 때, 다른 쓰레드에서 같은 대입으로
>>변수값이 오염(? ^^;)될 수 있고,
>>또한 변수 값을 수정했을 때, 상대에게 어떻게 알려 주느냐 하는 것이죠.
>>
>>물론 데이터의 신뢰는 세마포어를 이용하고 동기를 맞추기 위해서는
>>계속 변수값을 확인하거나 다른 변수를 또 두는 방법이 있습니다만,
>>필요한 변수가 하나씩 늘면 전체적으로 매우 어지러운 코드가 되기 쉽습니다.
>>
>>처음 코드가 어렵지만 프로그램이 커지더라도 데이터 처리가 상대적으로 커지지 않는
>>IPC 방법을 권하고 싶습니다. 저는 특히 UDS방식을 애용합니다.
>>
>>UDS는 UDP통신을 하듯 자료를 주고 받기 때문에 데이터의 신뢰성과
>>수신한 상대 쪽에서 바로 데이터를 처리할 수 있는 등의 장점이 있습니다.
>>
>>UDS에 대한 자세한 내용은 아래의 링크를 참고해 주세요.
>>
>>http://forum.falinux.com/bbs/view.php?id=lecture2&no=181
>>
>>또한 쓰레드에서는 광역변수 문제가 또 있습니다.
>>C 함수 중에는 광역 변수를 사용하는 함수가 있습니다.
>>쓰레드를 사용하실 때 광역 변수를 사용하는 함수를 사용하시면 이상한 오류를 발생할 수 있습니다.
>>
>>그러므로 간단한 경우라면 쓰레드도 좋습니다만 가급적 프로세스 생성을 권하고 싶습니다.
>>
>>모쪼록 학습하시는데 조그만 도움이되는 글이었으면 좋겠습니다. ^^
>>
>>>안녕하세요 ESP-MMI 보드로 맹렬히 연습하고 있는 비기너 입니다.
>>>
>>>지난번에 질문 드린 내용이 프로세스가 복수 개일때 데이터 공유에 대한 내용이었는데, 그 때 공유메모리를 소개해 주셨었습니다.
>>>
>>>그런데, 제가 프로세스와 쓰레드에 대해 개념이 없어서 질문을 잘못 드린 것이었는데요...
>>>
>>>다시 질문을 드리면, 하나의 프로세스 내에서 두 개의 쓰레드를 실행시킬 때의 데이터 공유에 대한 문제 입니다.
>>>
>>>1. 일단, 한 프로세스 내의 쓰레드는 같은 메모리 공간을 사용한다는 베이스에서, 프로세스 내에서 전역 변수를 잡아서 사용하니 두 개의 쓰레드 사이에 제가 원하는 데이터 전달이 실행이 되었습니다. 단, 전달된 데이터를 읽어서 다음 액션을 취하는 타이밍이 항상 동일하지 않다는 점이 문제라고 생각되는데...이것은 소위 말하는 자원 동기화 라는 것으로 해결되는 것인가요?
>>>
>>>2. 위의 상황에서 처럼 전역 변수로 데이터를 공유하는 것이 바람직한 또는 일반적인 방법인가요?
>>>
>>>3. 자료를 찾아보니(소개해 주신 joinC) 쓰레드 사이의 데이터 교환에 관해서 전통적인 IPC 방법도 소개하고 있던데, 같은 프로세스 내에 존재하는 쓰레드 사이에서 공유메모리를 이용한 데이터 교환이 가능한 것인가요? 그리고 바람직한 것인가요? (아무리봐도 그냥 전역변수 쓰는 것보다는 복잡하다는 생각이 들어서..)
>>>
>>>비가 많이 옵니다. 참 공부하기 좋은 날씨네요...
>>>항상 우문에 현답을 주심에 감사드리니다.
>>
>