본문 바로가기

쓰기

콘솔...이라고 써뒀지만 콘솔도 아닙니다 'ㅅ'

걍 Shift-JIS로 된 파일을 휙 던져 넣으면 알아서 번역해서
파일명_new.확장자로 번역해서 만들어주도록 되어있는 녀석입니다.


QuickTrans 쓰려다가 영 귀찮아서 MFC판 QuickTrans 만드는데 연습할 겸 해서
일단 스마가 기준으로 만들었는데,
한가지 문제가 발생합니다.



아랄트랜스의 ezTransXP.dll을 '네번' 로드한뒤
번역 명령을 내리는 식으로 멀티스레드를 구현했는데,

결과적으로는 네개를 동시에 불러도 돌아가긴 똑같이 돌아가는듯한 느낌입니다 -_-?

왜 그럴까요?
조회 수 :
13002
등록일 :
2009.08.11
22:08:24
엮인글 :
https://arallab.hided.net/26373/094/trackback
게시글 주소 :
https://arallab.hided.net/board_devtalk/26373

whoami

2009.08.12
23:34:41
음. 질문의 요지가 명확치는 않군요. 쓰레드가 4개 돌아가는데 쓰레드 1개 돌아가는 것과
 일하다는 것인지 아니면 ezTransXP.dll 을 4개 로드했는데 ezTransXP.dll 을 1개 로드한것과
 같다는 뜻인지.. 혹은 전혀 다른 질문인지..

일단, 소스를 한번 훑어보니 확실히 잘못 알고 계신 것이 하나 있어 말씀드립니다.

DLL 은 같은 이름 (같은 path 의 같은 이름의 dll) 인 경우 메모리에는 *단 한번* 올라갑니다.
두 번째 부터는 실제 DLL 이 올라가는 것이 아니라 레퍼런스 카운트만 하나씩 올라갑니다.
그러다가 FreeLibrary 가 불릴 때 마다 레퍼런스 카운트를 하나씩 빼 가다가 마지막 하나가
FreeLibrary 되는 순간 메모리에서 삭제됩니다.

그래서.. 어떤 프로그램이 Kernel32.dll 을 불러 사용하고, 또 그 프로그램이 불러오는 각각의
다른 DLL 마다 Kernel32.dll 을 또 불러 사용하는데도 (Dependency Walker 로 확인할 수 있습니다)
메모리 부족 에러가 나지 않고 제대로 돌아가는 것입니다. 반대로, MFC 등을 사용할 때 MFC라이브러리를
동적으로 링크 시킬 때 메모리가 많이 절약되는 이유이기도 하고요.

DllMain() 이라는 함수를 기억하실지 모르겠네요. DLL 의 엔트리 포인트 격의 역할을 하는
함수인데요, 맨 처음 DLL이 메모리에 Load되면 DLL_PROCESS_ATTACH 를 받고,
그 이후부터는 DLL_THREAD_ATTACH 를 받으며, Free 될 때마다 DLL_THREAD_DETACH
를 받다가.. 마지막에 메모리에서 사라질때 DLL_PROCESS_DETACH 를 받습니다.
자세한 사항은 DllMain() 관련 설명을 참조하세요.

그러다보니.. 주의사항도 있습니다. DLL 에서는 *전역변수* 를 쓰는 것을 조심해야 합니다.
왜냐하면 메모리에 단 한번 로드되기 때문에 그 전역변수를 모든 쓰레드에서 공유하기 때문이죠.

예를 들어.. A.exe 라는 프로그램이 B.dll, C.dll 을 쓰는데, B.dll 은 내부적으로 C.dll 을 불러 쓴다고
합시다. 그런데 C.dll 에는 내부에서 전역변수로 strWorkFile 이라는 변수를 두고 여기에 현재 작업중인
파일명을 저장해 둡니다.

이제 A.exe 에서 strWorkPath = C:/work.txt 로 해서 작업을 하고 있다가 B.dll 의 함수 하나를 불렀습니다.
B.dll 은 strWorkPath 를 내부적으로 C:/temp.txt 로 바꾸고 작업을 했습니다. 이제 A.exe 에서 strWorkPath
를 다시 불러와 작업을 하려고 보니 작업한 내용을 못 찾는 것이죠.

이와 같은 문제가 MultiPlugin 에서도 있었습니다.. 갑자기 아랄트랜스와 연관된 주제가 나와서 놀라셨죠? ^^
예전 MultiPlugin1 에서는 Translate() 만을 통해서 아랄 - 필터(pre) - 번역 - 필터(post) - 아랄 로 돌려주게
되어 있었습니다. 그러다보니 필터(pre)와 필터(post) 로 두 번 로드시켜야 하는데 메모리에는 한 번밖에
로드가 안되니 환장할 노릇이었죠. 처음에는 bool 전역변수로 pre 에서 true 로 바꿔놓고 post 에서
false 로 하는 방법을 사용했는데.. 그러다보니 중간에 번역포기를 할 때 방법이 없더군요; 그래서
pre필터, post필터 로 같은 DLL 을 2개 만들어 보았더니.. pre 와 post 로 2개 나뉘어서 복잡할 뿐더러
두 DLL 간의 데이터 공유가 어려웠습니다.. 그래서 결국은 인터페이스 규약을 확장시켜서
PreTranslate() 와 PostTranslate() 를 따로 사용하는 MultiPlugin2 가 나오게 된 것이랍니다. ^^

현재의 플러그인 (알고리즘, 필터, 번역 포함)은 "반드시 한번만 Load 된다" 라는 전제를 가지고
제작되며 또 아랄에서 그렇게 제어하기 때문에 전역변수를 마음껏 사용해도 됩니다만.. 필터 추가창을
잘 보시면 "중복 추가 허용" 체크박스가 있고 그걸 체크하면 중복 추가도 가능합니다. 물론
중복 추가를 염두에 두고 만든 필터만 사용해도 부작용이 없으며 체크시 경고문이 뜨는 이유도
여기에 있습니다.

뭐.. 이걸로 이야기하다 보면 또 한이 없으니.. 더 궁금하신게 있으면 그때 다시 적도록 하죠.
List of Articles
번호 제목 글쓴이 조회 수 추천 수sort 날짜 최근 수정일
공지 Talk [필독] 테스트필터 사용시 주의사항 라파에 155439   2008-08-03 2008-12-16 00:03
289 Archive [플러그인] DenyWord 테스트 버전 20080924 [1] file Hide_D 10891   2008-09-24 2009-01-06 01:24
 
288 Talk 픽스 라인 연기로 인한 임시 대책 Hide_D 10821   2008-09-26 2009-01-06 01:24
본래 목적인 FixLine이 완성이 늦춰지면서 약간 작전을 변경하도록 하겠습니다. FixLine을 완성시키는 것은 유지하고 FixLine을 3개로 쪼갭니다. OutRuby : FixLine의 TextOnly옵션 DivideLine : FixLine의 Base 기능(DCOnly 대체용) FixChar : FixLine의 Add...  
287 Archive [플러그인] DivideLine 테스트 버전 20080927 [1] file Hide_D 10926   2008-09-27 2009-01-06 01:24
 
286 Talk 으아아앍 SVN [1] Hide_D 10267   2008-09-27 2009-01-06 01:24
구조가 꼬였네요 orz 어쩌지[...]  
285 Archive [플러그인] OutRuby 테스트 버전 20080927 [2] file Hide_D 10236   2008-09-27 2008-10-12 03:58
 
284 Talk ...? [3] file 북극 12001   2008-09-28 2008-12-30 08:55
 
283 Talk [질문] J2kEngine.dll 에관해 이것저것 [3] 호기심맨 16881   2008-09-29 2009-01-06 01:24
회원님들이 올려주신 소스와 답변덕에 더디지만 조금씩 EzTranceXp안에 UserDict.jk 파일 편집프로그램을 완성해 나가고 있습니다. 다시 한번 모든분들께 감사드리고요 (꾸벅) 염치없지만 다시 막힌부분에서 질문 또 올리게 되었습니다. 1. dll 파일에서 함수...  
282 Talk SVN 말이죠 ㅠ_ㅠ [3] file Hide_D 11128   2008-09-29 2009-01-06 01:24
 
281 Talk 죄송해요 ㅠ_ㅠ SVN 위치 trunk -> trunk2 로 옮겨주세요. Hide_D 10477   2008-10-01 2009-01-06 01:24
제가 세팅을 잘못한 모양인지 trunk 그 상태로는 도저히 원상 복구가 안되네요 ㅠ_ㅠ 죄송합니다 위치를 trunk에서 trunk2로 바꿔주시면 감사하겠습니다  
280 Talk DumpText2 계획안 [6] file Hide_D 14432   2008-10-02 2009-01-06 01:24
 
279 Talk 사용자대본 지나가다정착한이A님 특별판[...] file Hide_D 11242   2008-10-02 2009-01-06 01:24
 
278 Archive 정착한A님 여기 ATCode.dll 이거!! [3] file 아랄 20120   2008-10-07 2009-01-06 01:24
 
277 Talk 기리기리 스크립트. 원본, 작업물. file 나는누구인감? 11933   2008-10-07 2008-10-07 22:53
 
276 Archive [소스, 파일] 기리기리, 페이트 전용 매크로(완료) [4] file Hide_D 11256   2008-10-07 2008-10-09 00:08
 
275 Archive 임시 소스 보관 DumpText2 file Hide_D 10305   2008-10-11 2009-01-06 01:52
 
274 Archive [플러그인] OutRuby 테스트 버전 20081012 file Hide_D 9206   2008-10-12 2008-10-12 11:30
 
273 OtherFiles vs2008 - Remote Debugging file 아랄 12710   2008-10-13 2008-10-13 23:55
 
272 Talk 기리기리 버그, [6] Hide_D 13829   2008-10-19 2009-01-06 01:48
기리기리에서는 라인 외부 함수로 @,*를 사용하고 내부 함수(매크로?)로 [] 를 사용하고 있는데, []안에 올바른 매크로가 들어가지 않는 경우, 튕겨버립니다 ezTransXP나 KiriKiri나 둘중에 한녀석 손좀 봐둬야 할듯 =ㅅ=; http://www.aralgood.com/zbxe/13278...  
271 Talk ATCode UI 버그 [1] Hide_D 11730   2008-11-01 2009-01-06 01:03
HOOK(0x00480A10,TRANS([ESP+0x28],PTRCHEAT,SAFE)),ENCODEKOR,HOOK(0x005622B0,TRANS([ESP+0x4],PTRCHEAT ​ ,SAFE)),HOOK(0x00562CB0,TRANS([ESP+0x4],PTRCHEAT,SAFE)),HOOK(0x004F5590,TRANS([ESP+0x4],PTRCHEAT,SAFE)) ​ ,HOOK(0x00481790,TRANS([ESP+0x40]...  
270 Talk ATLAS 삽질중.. [3] file 아랄 13771   2008-11-09 2009-01-06 01:15