Microsoft MVP성태의 닷넷 이야기
오류 유형: 6. [VC++ 컴파일] already defined in ntdll.lib(ntdll.dll) [링크 복사], [링크+제목 복사],
조회: 30467
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

솔직히 이 현상을 재미있다고 표현해야 할지 모르겠지만.

최근에, 제가 "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"으로 돌려놓습니다. 참, 재미있게도... 이젠 정상적으로 프로젝트가 컴파일되어집니다. ^^






[최초 등록일: ]
[최종 수정일: 11/22/2022]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 121  122  [123]  124  125  126  127  128  129  130  131  132  133  134  135  ...
NoWriterDateCnt.TitleFile(s)
10849정성태9/14/201557103오류 유형: 307. CLR20r3 오류 해결을 위해 mscorlib.dll을 덮어쓸때 주의할 점 [12]
10848정성태9/8/201527478VS.NET IDE: 103. Visual Studio의 Ctrl + F5 실행 동작파일 다운로드1
10847정성태9/8/201523535VS.NET IDE: 102. 목록(List) 타입의 값을 디버깅 중 Watch 창에서 확인하는 방법 [1]파일 다운로드1
10846정성태9/8/201520943오류 유형: 306. "query user" 명령어에 공백 문자가 포함된 계정을 전달하는 경우
10845정성태9/3/201522057오류 유형: 305. 윈도우 백업 시 오류 - 0x80780166
10844정성태9/2/201523257.NET Framework: 528. C# - 상호 참조하는 경우의 정적 생성자 동작 방식 [4]파일 다운로드1
10843정성태9/1/201523986VS.NET IDE: 101. Visual Studio 2015의 솔루션 탐색기가 클래스 뷰 정보로 인해 느려지는 현상
10842정성태9/1/201520980.NET Framework: 527. 닷넷 사용자 정의 예외 클래스의 최소 구현 코드 - 세 번째 이야기
10841정성태8/31/201530330개발 환경 구성: 276. Visual Studio 2013에서 C# 6과 닷넷 4.6 기능을 사용하려면?
10839정성태8/22/201528841Windows: 112. 윈도우 10에서 터치 키보드를 안 뜨게 할 수 있는 방법 [4]
10838정성태8/22/201539146오류 유형: 304. Windows 10에서 VPN 연결이 실패한다면? [3]
10837정성태8/21/201519452오류 유형: 303. Your computer is low on memory. Save your files and close these programs...
10836정성태8/21/201520458오류 유형: 302. 설치 파일 실행 시 "This app can't run on your PC" 오류가 뜬다면?
10835정성태8/21/201528894웹: 31. Microsoft Edge 브라우저를 명령행에서 띄우는 방법 [1]
10834정성태8/19/201521036.NET Framework: 526. 닷넷 - 값 형식을 new 없이 생성하면 0으로 초기화되지 않는다?
10833정성태8/18/201525661.NET Framework: 525. C# - 닷넷에서 프로세스가 열고 있는 파일 목록을 구하는 방법파일 다운로드1
10832정성태8/17/201530047디버깅 기술: 74. x64 콜 스택 인자 추적과 windbg의 Child-SP, RetAddr, Args to Child 값 확인 [8]파일 다운로드2
10831정성태8/13/201530043.NET Framework: 524. .NET 4.0과 .NET 4.5의 컴파일 결과 차이점 [1]파일 다운로드1
10830정성태8/12/201524059개발 환경 구성: 275. Web.config이 적용되지 않는 프로젝트에서 Razor 템플릿 파일의 C# 컴파일러 버전 제어 [1]
10829정성태8/10/201526153개발 환경 구성: 274. PowerShell/명령행에서 JDK/JRE를 무인(unattended)/자동 설치를 하는 방법 [3]
10828정성태8/10/201531741웹: 30. Edge 브라우저에서 "이 웹 사이트에는 Internet Explorer가 필요함" 단계를 없애는 방법 [1]
10827정성태7/8/201533074개발 환경 구성: 273. Visual Studio 2015에서 Github와 연동하는 방법 [3]
10826정성태7/8/201522741오류 유형: 301. The trust relationship between this workstation and the primary domain failed. - 두 번째 이야기
10825정성태7/8/201522315개발 환경 구성: 272. Visual Studio IDE 설치 없이 Visual Studio SDK 설치하는 방법
10824정성태7/7/201527469개발 환경 구성: 271. Team Foundation Server 2015 설치 방법 [1]
10823정성태7/7/201527949오류 유형: 300. SqlException (0x80131904): Unable to open the physical file
... 121  122  [123]  124  125  126  127  128  129  130  131  132  133  134  135  ...