솔직히 이 현상을 재미있다고 표현해야 할지 모르겠지만.
최근에, 제가 "Windows 구조와 원리 그리고 Codes"라는 책을 읽고 있습니다.
거기 나온 예제를 컴파일 해보려고 했는데요.
참고로, 그 책의 소스는 아래 게시판에 "2번" 게시물로 등록되어져 있습니다.
http://cafe.naver.com/andyjung.cafe?iframe_url=/ArticleList.nhn%3Fclubid=11534822%26menuid=8%26boardtype=L%26page=
압축 파일을 풀면 "Windows_Codes" 폴더 밑으로, "ListHandles"라는 폴더가 보입니다.
제가 컴파일한 예제는 그 프로젝트입니다.
그 프로젝트를 컴파일하려면 ntdll.lib 파일이 필요한데, 이 파일은 SDK에는 포함되어 있지 않은 것으로, NT DDK를 다운로드/설치해야만 합니다. (DDK는 MSDN Subscriber에 가입된 경우에만 다운로드가 가능합니다.) 설치 후, lib 폴더를 VS.NET 2005의 "Options" 메뉴를 통해서 등록해 두어야 합니다.
어쨌든, 우여곡절 끝에 환경 구성을 한 다음.
제 컴파일 환경은 VS.NET 2005의 VC++ 8.0입니다. 그 예제는 dsw로 되어 있어서, 더블 클릭을 하게 되면 VS.NET 2005는 우선 프로젝트 변환을 하겠다고 합니다.
정상적으로 변환된 후, 컴파일을 시도하면 다음과 같은 오류가 발생합니다.
Linking...
LIBCMTD.lib(strtol.obj) : error LNK2005: _strtoul already defined in ntdll.lib(ntdll.dll)
.\Debug/ListHandles.exe : fatal error LNK1169: one or more multiply defined symbols found
Build log was saved at "file://d:\Snippet\BookCode\Windows_Codes\ListHandles\Debug\BuildLog.htm"
ListHandles - 2 error(s), 0 warning(s)
========== Build: 0 succeeded, 1 failed, 0 up-to-date, 0 skipped ==========
자, 이제 프로젝트 설정에서 "Use of MFC" 옵션을 기존의 "Use Standard Windows Libraries"에서 "Use MFC in a Shared DLL"로 바꿔주고 컴파일을 합니다.
이번엔 다음과 같이 오류가 발생합니다.
------ Build started: Project: ListHandles, Configuration: Debug Win32 ------
Linking...
ListHandles.obj : error LNK2019: unresolved external symbol __imp__AdjustTokenPrivileges@24 referenced in function "int __cdecl EnablePrivilege(char const *)" (?EnablePrivilege@@YAHPBD@Z)
ListHandles.obj : error LNK2019: unresolved external symbol __imp__OpenProcessToken@12 referenced in function "int __cdecl EnablePrivilege(char const *)" (?EnablePrivilege@@YAHPBD@Z)
ListHandles.obj : error LNK2019: unresolved external symbol __imp__LookupPrivilegeValueA@12 referenced in function "int __cdecl EnablePrivilege(char const *)" (?EnablePrivilege@@YAHPBD@Z)
.\Debug/ListHandles.exe : fatal error LNK1120: 3 unresolved externals
Build log was saved at "file://d:\Snippet\BookCode\Windows_Codes\ListHandles\Debug\BuildLog.htm"
ListHandles - 4 error(s), 0 warning(s)
========== Build: 0 succeeded, 1 failed, 0 up-to-date, 0 skipped ==========
자... ^^; 이제 다시 "Use MFC in a Shared DLL" 옵션을 원래의 "Use Standard Windows Libraries"으로 돌려놓습니다. 참, 재미있게도... 이젠 정상적으로 프로젝트가 컴파일되어집니다. ^^
No | Writer | Date | Cnt. | Title | File(s) |
11896 | 정성태 | 5/15/2019 | 25120 | 개발 환경 구성: 440. C#, C++ - double의 Infinity, NaN 표현 방식 | 1 |
11895 | 정성태 | 5/12/2019 | 22656 | .NET Framework: 832. ML.NET Model Builder - 회귀(Regression), 다중 분류(Multi-class classification) 예제 | 1 |
11894 | 정성태 | 5/10/2019 | 24606 | VS.NET IDE: 135. Visual Studio - ML.NET Model Builder 소개 [5] | |
11893 | 정성태 | 5/10/2019 | 20643 | 오류 유형: 535. C# 6.0 이상의 문법을 컴파일 시 오류가 발생한다면? | |
11892 | 정성태 | 5/10/2019 | 20546 | 웹: 38. HTTP Cookie의 expires 시간 형식(RFC7231) | |
11891 | 정성태 | 5/9/2019 | 23663 | .NET Framework: 831. (번역글) .NET Internals Cookbook Part 12 - Memory structure, attributes, handles | |
11890 | 정성태 | 5/8/2019 | 19378 | 개발 환경 구성: 439. "Visual Studio Enterprise is required to execute the test." 메시지와 관련된 코드 기록 | |
11889 | 정성태 | 5/8/2019 | 19435 | 개발 환경 구성: 438. mstest, QTAgent의 로그 파일 설정 방법 | |
11888 | 정성태 | 5/8/2019 | 37318 | .NET Framework: 830. C# - 비동기 호출을 취소하는 CancellationToken의 간단한 예제 코드 [1] | 1 |
11887 | 정성태 | 5/8/2019 | 23116 | .NET Framework: 829. C# - yield 문을 사용할 수 있는 메서드의 조건 | |
11886 | 정성태 | 5/7/2019 | 20190 | 오류 유형: 534. mstest.exe 실행 시 "Visual Studio Enterprise is required to execute the test." 오류 [2] | |
11885 | 정성태 | 5/7/2019 | 17662 | 오류 유형: 533. mstest.exe 실행 시 "File extension specified '.loadtest' is not a valid test extension." 오류 발생 | |
11884 | 정성태 | 5/5/2019 | 22580 | .NET Framework: 828. C# DLL에서 Win32 C/C++처럼 dllexport 함수를 제공하는 방법 - 두 번째 이야기 | |
11883 | 정성태 | 5/3/2019 | 27580 | .NET Framework: 827. C# - 인터넷 시간 서버로부터 받은 시간을 윈도우에 적용하는 방법 | 1 |
11882 | 정성태 | 5/2/2019 | 24080 | .NET Framework: 826. (번역글) .NET Internals Cookbook Part 11 - Various C# riddles | 1 |
11881 | 정성태 | 4/28/2019 | 24200 | 오류 유형: 532. .NET Core 프로젝트로 마이그레이션 시 "CS0579 Duplicate 'System.Reflection.AssemblyCompanyAttribute' attribute" 오류 발생 | |
11880 | 정성태 | 4/25/2019 | 19920 | 오류 유형: 531. 이벤트 로그 오류 - Task Scheduling Error: m->NextScheduledSPRetry 1547, m->NextScheduledEvent 1547 | |
11879 | 정성태 | 4/24/2019 | 28798 | .NET Framework: 825. (번역글) .NET Internals Cookbook Part 10 - Threads, Tasks, asynchronous code and others | 2 |
11878 | 정성태 | 4/22/2019 | 24133 | .NET Framework: 824. (번역글) .NET Internals Cookbook Part 9 - Finalizers, queues, card tables and other GC stuff | 1 |
11877 | 정성태 | 4/22/2019 | 24311 | .NET Framework: 823. (번역글) .NET Internals Cookbook Part 8 - C# gotchas | 1 |
11876 | 정성태 | 4/21/2019 | 22523 | .NET Framework: 822. (번역글) .NET Internals Cookbook Part 7 - Word tearing, locking and others | 1 |
11875 | 정성태 | 4/21/2019 | 24378 | 오류 유형: 530. Visual Studo에서 .NET Core 프로젝트를 열 때 "One or more errors occurred." 오류 발생 | |
11874 | 정성태 | 4/20/2019 | 24408 | .NET Framework: 821. (번역글) .NET Internals Cookbook Part 6 - Object internals | 1 |
11873 | 정성태 | 4/19/2019 | 23112 | .NET Framework: 820. (번역글) .NET Internals Cookbook Part 5 - Methods, parameters, modifiers | 1 |
11872 | 정성태 | 4/17/2019 | 23963 | .NET Framework: 819. (번역글) .NET Internals Cookbook Part 4 - Type members | 1 |
11871 | 정성태 | 4/16/2019 | 21816 | .NET Framework: 818. (번역글) .NET Internals Cookbook Part 3 - Initialization tricks [3] | 1 |