로그인

검색

MoA
조회 수 4313 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 게시글 수정 내역 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 게시글 수정 내역 댓글로 가기 인쇄
안녕하세요 갱주니 입니다. 최근에 제목과 같은 질문을 받았습니다.
그것에 대해서 정리를 했습니다.
 
[질문내용] 
안녕하세요. 혹시 시간 나실 때 제 질문에 대해서 답변 부탁합니다.
저희팀에서 사용하는 로그함수가 로그를 남길 때

log.write()
{
    fopen();
    fwrite();
    fclose();
}

라는 식으로 로그를 남길 때마다 파일을 열고,쓰고 닫습니다.

이런식으로 할 때는 lock을 걸지 않아도 동기화에 문제가 없으리라 생각하는데 경준님 생각은 어떠신가요? 유닉스 계열에는 스레드에 안전하다는 글이 명시적으로 있는데 윈도우에는 된다 안된다라는 말이 없어서 애매하네요

당연히 fopen 은 CRT 함수입니다.
 
[답변 내용]
구글 검색을 통해서 다음 URL에서 찾았습니다. ( http://support.microsoft.com/kb/104641/en-us )
 여기서  설명은 이렇습니다.
 이미 그렇게 하고 있으시겠지만
 
스레드를 생성하는 방법은 두가지가 있다. 첫번째 방법은 CRT 함수 _beginthread() or _beginthreadex()를 사용하는 것이다. 다른 방법은
CreateThread() 를 이용하는 방법이다. 거의 모든 CRT 함수는 2가지 스레드 생성 방법에서 잘동작한다. 그러나 CreateThread()로 생성하고 CRT 함수를 사용하면 some problems가 있다.
 
There are two ways to create threads. One method involves using the CRT _beginthread() or _beginthreadex() (with Visual C++ 2.0 and later); the other method involves using the CreateThread() API. All CRT functions other than the signal() function work correctly in threads created with either _beginthread() or CreateThread(). However, there are some problems involved with using CRT functions in threads created with CreateThread(). 
스레드 생성과 시작 WIN32 API는 CreateThread() and ExitThread() 이것이다. 그런데 이 2개 API는 CRT 함수가 사용하는 static data and static buffers 를 스레드가 종료되면서 cleaned up 삭제하지 못한다. 예를 들어 static data for errno and _doserrno and the static buffers 이 두개 값은 asctime(), ctime(), localtime(), gmtime(), and mktime()이러한 CRT 함수에서 사용된다. CreateThread() 를 이용해서 스레드를 생성하고 종료하면 70~80 byte 메모리 Leak 이 생긴다.

Threads that are created and terminated with the CreateThread() and ExitThread() Win32 API functions do not have memory that is allocated by the CRT for static data and static buffers cleaned up when the thread terminates. Some examples of this type of memory are static data for errno and _doserrno and the static buffers used by functions such as asctime(), ctime(), localtime(), gmtime(), and mktime(). Using CreateThread() in a program that uses the CRT (for example, links with LIBCMT.LIB) may cause a memory leak of about 70-80 bytes each time a thread is terminated. 
모든 static data and static buffers 를 보장하기 위해서는 스레드를 생성 종료할때 _beginthreadex() and _endthreadex() 를 사용해야 한다. _beginthreadex() 함수는 CreateThread()동일한 파라미터로 만들어져 있다.
To guarantee that all static data and static buffers allocated by the CRT are cleaned up when the thread terminates, _beginthreadex() and _endthreadex() should be used when creating a thread. The _beginthreadex() function includes the same parameters and functionality as CreateThread(). 
주의 스레드를 CreateThread()로 생성한후 _endthreadex() 로 종료하는 것은 불가능 하다.
Note It is not possible to terminate a thread with _endthreadex() when it was created with CreateThread().
 

결론 위 질문과 같은 함수 내에서는 beginthreadex, endthreadex 로 처리하면 crt 내의 static data, static buffer 를 안전하게 처리해서 lock 없이 사용하셔도 된다.
출처 : 다년간의 프로그램밍 경험(삽질) & MSDN
 
감사합니다.

?

List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
공지 Tool/etc Programming 게시판 관련 2 MoA 2014.11.01 21871
325 Tool/etc 원격 서버 개발용 편집기로 Helix 에디터를 활용하는 방법 OBG 2025.10.29 153
324 LLM Claude Skills는 굉장하다, MCP보다 더 큰 혁신일지도 OBG 2025.10.29 170
323 Tool/etc 오픈 노트북(Open Notebook): Google의 Notebook LM을 대체하는 오픈소스 플랫폼 OBG 2025.10.29 189
322 Tool/etc SQLite Online - 11년간 1인이 개발, 하루 1.1만 명 사용 OBG 2025.10.15 845
321 Web 알아두면 유익한 2019 개발이야기 OBG 2025.09.15 1179
320 LLM 구글 개발자가 말하는 나노바나나의 진짜 실체 OBG 2025.09.07 1251
319 Agent Spec Kit(Spec-Driven Development) OBG 2025.09.15 1272
318 Agent 초보를 위한 Claude Code 안내서 OBG 2025.09.15 1319
317 LLM 나노바나나 공식 출시! 구글 제미나이에서 직접 사용하는 방법 OBG 2025.09.07 1322
316 LLM llama.cpp gpt-oss-120b 5090으로 돌려본 후기 OBG 2025.09.07 1353
315 Tool/etc Show GN: 유튜브 영상/웹페이지를 10초만에 구조화된 노트로 만드는 크롬 확장프로그램 OBG 2025.09.07 1433
314 모던 Node.js 패턴 (2025) OBG 2025.08.07 1435
313 LLM macOS에서 로컬 LLM 실험하기 OBG 2025.09.15 1441
312 Tool/etc VIM Master - Vim 명령어를 배우는 가벼운 브라우저 게임 OBG 2025.09.07 1457
311 Agent Vibe Code an MVP Web App OBG 2025.08.28 1521
310 Agent Kimi K2 클로드 코드와 함께 사용하는 방법 OBG 2025.08.28 1559
309 Agent Claude Code를 최고의 설계 파트너로 만들기 OBG 2025.08.28 1614
308 Deeplearning I Want Everything Local — Building My Offline AI Workspace OBG 2025.08.28 1625
307 Web JSON.stringify를 두 배 이상 빠르게 만든 방법 OBG 2025.08.07 1650
306 Agent 코딩 에이전트 만드는 법 OBG 2025.08.28 1679
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 17 Next
/ 17