성태의 닷넷 이야기
홈 주인
모아 놓은 자료
프로그래밍
질문/답변
사용자 관리
사용자
메뉴
아티클
외부 아티클
유용한 코드
온라인 기능
MathJax 입력기
최근 덧글
[정성태] Detecting blocking calls using asyn...
[정성태] 아쉽게도, 커뮤니티는 아니고 개인 블로그입니다. ^^
[정성태] 질문이 잘 이해가 안 됩니다. 우선, 해당 소스코드에서 ILis...
[양승조
] var대신 dinamic으로 선언해서 해결은 했습니다. 맞는 해...
[양승조
] 또 막혔습니다. ㅠㅠ var list = props[i].Ge...
[양승조
] 아. 감사합니다. 어제는 안됐던것 같은데....정신을 차려야겠네...
[정성태] "props[i].GetValue(props[i])" 코드에서 ...
[정성태] 저렇게 조각 코드 말고, 실제로 재현이 되는 예제 프로젝트를 압...
[정성태] Modules 창(Ctrl+Shift+U)을 띄워서, 해당 Op...
[정성태] 만드실 수 있습니다. 단지, Unity 엔진 내의 스크립트와 W...
글쓰기
제목
이름
암호
전자우편
HTML
홈페이지
유형
제니퍼 .NET
닷넷
COM 개체 관련
스크립트
VC++
VS.NET IDE
Windows
Team Foundation Server
디버깅 기술
오류 유형
개발 환경 구성
웹
기타
Linux
Java
DDK
Math
Phone
Graphics
사물인터넷
부모글 보이기/감추기
내용
<div style='display: inline'> <h1 style='font-family: Malgun Gothic, Consolas; font-size: 20pt; color: #006699; text-align: center; font-weight: bold'>Visual C++ - MSIL .netmodule or module compiled with /GL found; restarting link with /LTCG; add /LTCG to the link command line to improve linker performance</h1> <p> 이전 글의 실습에서,<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > Visual C++ - .NET Core의 nethost.lib와 정적 링크 ; <a target='tab' href='https://www.sysnet.pe.kr/2/0/12419'>https://www.sysnet.pe.kr/2/0/12419</a> </pre> <br /> 마지막으로 남은 링커 경고를 정리해 보겠습니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > 1>------ Rebuild All started: Project: ConsoleApplication1, Configuration: Debug x64 ------ 1>pch.cpp 1>dllmain.cpp 1>ConsoleApplication1.cpp 1>platform.cpp 1>Generating Code... 1>libnethost.lib(nethost.obj) : <span style='color: blue; font-weight: bold'>MSIL .netmodule or module compiled with /GL found; restarting link with /LTCG; add /LTCG to the link command line to improve linker performance</span> 1>LINK : warning LNK4075: ignoring '/INCREMENTAL' due to '/LTCG' specification 1> Creating library E:\temp\x64\Debug\ConsoleApplication1.lib and object E:\temp\x64\Debug\ConsoleApplication1.exp 1>MSVCRTD.lib(initializers.obj) : warning LNK4098: defaultlib 'libcmt.lib' conflicts with use of other libs; use /NODEFAULTLIB:library 1>Generating code 1>Finished generating code 1>ConsoleApplication1.vcxproj -> E:\temp\x64\Debug\ConsoleApplication1.dll 1>Done building project "ConsoleApplication1.vcxproj". ========== Rebuild All: 1 succeeded, 0 failed, 0 skipped ========== </pre> <br /> 위에서 LNK4075는 전에도 한번 언급했습니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > Orcas - ComUtil로 인한 증분(/INCREMENTAL) 링크 옵션 사용 제한 ; <a target='tab' href='https://www.sysnet.pe.kr/2/0/499'>https://www.sysnet.pe.kr/2/0/499</a> </pre> <br /> 그러니까, libnethost.lib가 /GL 옵션(Whole Program Optimization)으로 빌드된 모듈이라 그것을 사용하는 측에서는 /LTCG(Link Time Code Generation) 링크를 하게 된다는 의미입니다. 따라서 어차피 사용하게 되는 거 우리 측도 /LTCG 옵션을 켜라는 건데요, 어쩔 수 없습니다. (아니면 그냥 경고를 계속 빌드 때마다 보면 됩니다.)<br /> <br /> 어쨌든, Linker / Optimization의 "Link Time Code Generation"을 켜면 이제 빌드 경고가 하나 줄어듭니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > 1>------ Rebuild All started: Project: ConsoleApplication1, Configuration: Debug x64 ------ 1>pch.cpp 1>dllmain.cpp 1>ConsoleApplication1.cpp 1>platform.cpp 1>Generating Code... 1><span style='color: blue; font-weight: bold'>LINK : warning LNK4075: ignoring '/INCREMENTAL' due to '/LTCG' specification</span> 1> Creating library E:\temp\x64\Debug\ConsoleApplication1.lib and object E:\temp\x64\Debug\ConsoleApplication1.exp 1>MSVCRTD.lib(initializers.obj) : warning LNK4098: defaultlib 'libcmt.lib' conflicts with use of other libs; use /NODEFAULTLIB:library 1>Generating code 1>Finished generating code 1>ConsoleApplication1.vcxproj -> E:\temp\x64\Debug\ConsoleApplication1.dll 1>Done building project "ConsoleApplication1.vcxproj". ========== Rebuild All: 1 succeeded, 0 failed, 0 skipped ========== </pre> <br /> 그런데, 이제는 /LTCG를 켰다고 해서 증분 링크 기능을 무시하겠다는 경고를 보냅니다. 이 경고도 없애고 싶다면 Linker / General의 "Enable Incremental Linking"을 "No (/INCREMENTAL:NO)"로 설정하면 됩니다. 하지만, 이렇게 하면 다시 이로 인해 /EDITANDCONTINUE 기능을 무시한다고 알립니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > 1>------ Rebuild All started: Project: ConsoleApplication1, Configuration: Debug x64 ------ 1>pch.cpp 1>dllmain.cpp 1>ConsoleApplication1.cpp 1>platform.cpp 1>Generating Code... 1>dllmain.obj : <span style='color: blue; font-weight: bold'>warning LNK4075: ignoring '/EDITANDCONTINUE' due to '/INCREMENTAL:NO' specification</span> 1> Creating library E:\temp\x64\Debug\ConsoleApplication1.lib and object E:\temp\x64\Debug\ConsoleApplication1.exp 1>MSVCRTD.lib(initializers.obj) : warning LNK4098: defaultlib 'libcmt.lib' conflicts with use of other libs; use /NODEFAULTLIB:library 1>Generating code 1>Finished generating code 1>ConsoleApplication1.vcxproj -> E:\temp\x64\Debug\ConsoleApplication1.dll 1>Done building project "ConsoleApplication1.vcxproj". ========== Rebuild All: 1 succeeded, 0 failed, 0 skipped ========== </pre> <br /> 그리고 이 경고를 없애려면, 링커가 아닌 "C/C++"의 "General"에서 "Debug Information Format" 설정을 "Program Dtabase for Edit And Continue (/ZI)"에서 "Program Database (/Zi)"로 낮춰야 합니다."<br /> <br /> 그럼, 결국 /GL로 시작한 링커 경고는 이렇게 마무리가 됩니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > 1>------ Rebuild All started: Project: ConsoleApplication1, Configuration: Debug x64 ------ 1>pch.cpp 1>dllmain.cpp 1>ConsoleApplication1.cpp 1>platform.cpp 1>Generating Code... 1> Creating library E:\temp\x64\Debug\ConsoleApplication1.lib and object E:\temp\x64\Debug\ConsoleApplication1.exp 1>MSVCRTD.lib(initializers.obj) : warning LNK4098: defaultlib 'libcmt.lib' conflicts with use of other libs; use /NODEFAULTLIB:library 1>Generating code 1>Finished generating code 1>ConsoleApplication1.vcxproj -> E:\temp\x64\Debug\ConsoleApplication1.dll 1>Done building project "ConsoleApplication1.vcxproj". ========== Rebuild All: 1 succeeded, 0 failed, 0 skipped ========== </pre> <br /> 그런데, 과연 이것이 어떤 의미가 있는 걸까요? 주요 원인인 libnethost.lib가 /GL 빌드된 것으로 인해, 이후 "디버그 편의성을 위한 옵션"들을 전부 꺼야 하는 상황이 된 것입니다.<br /> <br /> 따라서, 이 문제를 근본적으로 해결하려면 라이브러리(이 글에서는 libnethost.lib) 개발자 측에서 디버그 빌드와 릴리스 빌드를 따로 제공해 주는 것이 좋습니다. 실제로 "<a target='tab' href='https://www.sysnet.pe.kr/2/0/499'>Orcas - ComUtil로 인한 증분(/INCREMENTAL) 링크 옵션 사용 제한</a>" 글에서 링크했던 "comsuppw.lib"는 그것의 디버그 빌드 버전으로 "comsuppwd.lib"를 제공해 주고 있습니다. 그리고 그때 (베타) 당시에는 디버그 빌드 버전에도 /GL 링크를 해 문제가 되었지만, 지금 그 프로젝트를 빌드하면 그런 오류가 발생하지 않습니다.<br /> <br /> 어쨌든, 저 경고들은 전체적인 프로그램 개발에 영향을 주지 않지만, 개발의 편의성을 떨어뜨리는 결과를 가져오는 것에 불과하므로 무시해도 상관없습니다.<br /> <br /> <hr style='width: 50%' /><br /> <br /> 자, 그럼 마지막 LNK4098도 살짝 손봐야겠죠. 이에 대해서는 예전에도 다뤘듯이,<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > LINK : warning LNK4098: defaultlib 'nafxcw.lib' conflicts with use of other libs; use /NODEFAULTLIB:library ; <a target='tab' href='https://www.sysnet.pe.kr/2/0/12156'>https://www.sysnet.pe.kr/2/0/12156</a> </pre> <br /> "/NODEFAULTLIB:libcmt.lib" 옵션을 주면 됩니다. 그럼, 이제 비로소 깨끗한 빌드 메시지를 접하게 될 것입니다. ^^<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > Rebuild started... 1>------ Rebuild All started: Project: ConsoleApplication1, Configuration: Debug x64 ------ 1>pch.cpp 1>dllmain.cpp 1>ConsoleApplication1.cpp 1>platform.cpp 1>Generating Code... 1> Creating library E:\temp\x64\Debug\ConsoleApplication1.lib and object E:\temp\x64\Debug\ConsoleApplication1.exp 1>Generating code 1>Finished generating code 1>ConsoleApplication1.vcxproj -> E:\temp\x64\Debug\ConsoleApplication1.dll ========== Rebuild All: 1 succeeded, 0 failed, 0 skipped ========== </pre> </p><br /> <br /><hr /><span style='color: Maroon'>[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]</span> </div>
첨부파일
스팸 방지용 인증 번호
1502
(왼쪽의 숫자를 입력해야 합니다.)