본문 바로가기

쓰기

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

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


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



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

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

왜 그럴까요?
조회 수 :
13002
등록일 :
2009.08.11
22:08:24
엮인글 :
https://arallab.hided.net/26373/bf6/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
124 Talk [질문] MBCS와 #UNICODE의 관계 [7] 호기심맨 13663   2008-12-14 2008-12-14 22:16
무모한 용기가 화를 부른다고.... '나도 필터란걸 만들어보자' 하고 쓸데없는 결심을 하는 바람에(결심만)...... 요새 1년을 기다려온 투3도 손도못대고 ....... Visual Studio 2005란거 깔고 낑낑대고 있네요.. (왜인지는 모르겠지만 현제 다운받은 아랄소스...  
123 Talk Small Talk + StrongRoom = New Small Talk! Hide_D 12177   2008-12-16 2008-12-16 00:06
다시 통합 완료했습니다. 카테고리는 3개로 돌아갑니다. Talk : 내용 무 Archive : 플러그인 관련 파일들이 올라갑니다. OtherFiles : 플러그인 관련은 아니지만 파일인 경우! 카테고리 작업도 완료했습니다.  
122 Talk FixLine 테스트버전 081215 [1] file 그레이 20429   2008-12-16 2008-12-16 16:37
 
121 Talk [오류보고]ATcode 버퍼크기 무시 버그 [1] file HaruKaze 12813   2008-12-18 2009-01-06 00:56
 
120 Talk ezTransXP 플러그인 버그 =ㅅ=?? [2] Hide_D 12427   2008-12-20 2009-01-06 00:47
단순씨 사전 45608개 짜리 버전으로 테스트했을때 「すごい! えらい!! カッコイイ!!! さすが僕らのトライオン!」 이걸 번역하면 「대단해<히)! 대단하다! 멋있어! 과연 우리들의 트라이 온!」 요렇게 나오는데, 아랄트랜스에서 괄호제거 옵션을 ...  
119 Talk 아아아아앍 cmd /u !!!!!!!!!!!!!!!!!! [1] Hide_D 12323   2008-12-22 2009-01-06 00:47
cmd /? 해서 살펴보고 있는데 /u 플래그가 있었군요 /U 파이프 또는 파일로의 내부 명령어의 출력을 Unicode로 설정합니다. dir /s /b > UniDir.txt 로 했더니 UTF16-LE BOM없음으로 저장되는군요. 옴마야. 왜 모르고있었지  
118 Talk 기리기리 [] 함수 내부 처리 [1] Hide_D 12463   2008-12-23 2008-12-30 08:49
이것이 , 나의[荷物'ざいさん]의 모두였다. [ ' ] 로 나오는 경우 추가로 루비로 처리되는 모양입니다 이거 추가해둬야겠네요.  
117 Talk 쓰레드를 사용하려고 하는데 제대로 안되네요; [2] Hide_D 10808   2008-12-25 2008-12-26 22:53
음 일단 쓰레드를 사용하는 파일은 CAutoLoad 클래스 하나뿐이구요. CustomDic에 포함됩니다. 5초마다 한번씩 파일리스트에 등록된 파일의 수정된 날짜를 체크해서 새로 갱신된것이면 새로 읽는다...라는 기능을 가지고 있는데, 애초부터 쓰레드가 동작조차 하...  
116 Talk FixLine 23일자 파일은 무시설정에 문제가 있는듯하네요 [7] 류제로 15841   2008-12-26 2008-12-30 08:30
이번에 올라온 종말능의를 코드를 입력시켜면서 알게된 것인데 23일자 FixLine 옵션의 무시설정의 서클체크을 사용안함 이외 부분을 체크하고 확인을 누르면 적용은 되는듯하나 다시 옵션창을 열어보면 체크가 사용 안함으로 표시 되어있습니다 20일자로 실행...  
115 Talk 필터에 MFC로 모달리스 창을 띄웠을때=ㅅ=; [4] file Hide_D 13934   2008-12-27 2008-12-30 08:29
 
114 Talk Fixline용 텍스트 파일.... [3] file 처음처럼만 11753   2008-12-29 2008-12-30 09:02
 
113 Talk 히데님이 말씀하신 테스트파일 [2] file 유르_리샤 11530   2008-12-29 2008-12-30 08:25
 
112 Talk 음 제가 컴퓨터를 못하는 사람이라 뻘글일 수도 있겠지만.. [2] 쥬빌 14389   2008-12-30 2008-12-30 12:14
아랄 트랜스의 장점이 게임상의 대사가 바로 한글로 변환 표기되는 것이라 보는데요. 번역률을 높이기 위해 번역본이 있는 게임들은 ez트랜스가 아닌, 미연시 번역본 text과 연동하여 쓸수는 없을까요? ez와의 연동 구조를 잘 모르겠으나..게임상의 일어를 ez...  
111 Talk 디나이코필터 [2] my vagina 10993   2008-12-31 2009-01-15 00:10
코필터는 대단히 훌륭한 필터죠 근데 전부 한자로 되있으믄 간간히 해석 안되는 부분이 생기기도 하는데 어쩔수 없는 부분이 보이거든요. 이런걸 수동으로 억제 해보자는 생각이에요. 아마 코필터 내부에 들어가야 할텐데, 코필터에 디나이필터를 넣어서 일본...  
110 Talk 관리자님께 '옵션코드 입력'에 관해서 요청~ Hide_D 9990   2009-01-03 2009-01-03 11:02
일반적으로 아랄트랜스에서 '옵션'을 긁어 온다면 두가지 방법으로 긁어올수 있습니다. /a:ATCode{HOOK(0x004016B0,TRANS([ESP+0x8],PTRCHEAT))} /f:DumpText{SET(10100)} /t:ezTransXP{} 이 형식과 HOOK(0x004016B0,TRANS([ESP+0x8],PTRCHEAT)) DumpText{SET(...  
109 Talk [질문] CustomDic필터와 FixLine의 셋팅순서 [4] 호기심맨 11404   2009-01-03 2009-01-04 14:58
멀티플러그인 필터를 만들려고 하면서 제일 의문이 드는 부분인데요 그 필터들의 실행순서가 어떻게 결정되는지가 무척 궁금하네요 그러니까 예를 들어 A,B,C 3개의 필터를 순서대로 셋팅했다고 가정하면 제가 파악하기로는 알고리즘 코드 ↓ AFilter.OnPreTran...  
108 Talk CustomDic의 치환문자열에 대해 ( Hide님께) [2] 호기심맨 11323   2009-01-03 2009-01-05 00:04
안녕하세요 Hide님..저도 전부터 CustomDic유사한걸 만드드라 알아내고 여러번 Test해봐서 얻어낸 결론인데요.. 지금 Hide님이 정의하신 치환문자열"@*_D..../"보다는 역시 실제 쓰일리없는 엉망진창인 알파벳문자열이 훨씬 더 변역결과가 좋더군요. (주로 한...  
107 Talk 비주얼베이직에서의 Hash값 생성 코드 작업 file HaruKaze 9022   2009-01-05 2009-02-14 11:04
 
106 Talk 하루카제님 요청하신거 C++로 만들어봤습니다. [3] Hide_D 10779   2009-01-05 2009-01-05 18:30
// Test.cpp : 콘솔 응용 프로그램에 대한 진입점을 정의합니다. // #include <stdio.h> #include <tchar.h> #include <math.h> typedef unsigned int UINT; struct BoolArray{ bool Data[32]; }; BoolArray NewBoolArray(); UINT Algorithm(char * szSource)...  
105 Talk VB용 커스텀스크립트 Hash 함수 [2] HaruKaze 9835   2009-01-05 2009-02-14 11:01
비주얼베이직에서 사용할 수 있는 커스텀스크립트 Hash 생성 함수입니다. 비주얼베이직에서는 이진 변환과 이진 연산을 할 수 없기 때문에 이진 변환과 연산을 할 수 있게 해주는 함수를 작성하여 만들었습니다. - 정수를 이진 문자열로 변환하는 함수 - 이진...