Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)
(시리즈 글이 9개 있습니다.)
.NET Framework: 90. XmlSerializer 생성자의 실행 속도를 올리는 방법
; https://www.sysnet.pe.kr/2/0/511

.NET Framework: 92. XmlSerializer 생성자의 실행 속도를 올리는 방법 - 두 번째 이야기
; https://www.sysnet.pe.kr/2/0/521

.NET Framework: 100. XML Serializer를 이용한 값 복사
; https://www.sysnet.pe.kr/2/0/577

.NET Framework: 122. XML Serializer를 이용한 값 복사: 성능은 어떨까!
; https://www.sysnet.pe.kr/2/0/653

.NET Framework: 648. Dictionary<TKey, TValue>를 deep copy하는 방법
; https://www.sysnet.pe.kr/2/0/11157

.NET Framework: 660. Shallow Copy와 Deep Copy
; https://www.sysnet.pe.kr/2/0/11220

.NET Framework: 1141. XmlSerializer와 Dictionary 타입
; https://www.sysnet.pe.kr/2/0/12942

.NET Framework: 2078. .NET Core/5+를 위한 SGen(Microsoft.XmlSerializer.Generator) 사용법
; https://www.sysnet.pe.kr/2/0/13196

.NET Framework: 2080. C# - Microsoft.XmlSerializer.Generator 처리 없이 XmlSerializer 생성자를 예외 없이 사용하고 싶다면?
; https://www.sysnet.pe.kr/2/0/13198




.NET Core/5+를 위한 SGen(Microsoft.XmlSerializer.Generator) 사용법

예전에 설명한,

XmlSerializer 생성자의 실행 속도를 올리는 방법
; https://www.sysnet.pe.kr/2/0/511

XmlSerializer 생성자의 실행 속도를 올리는 방법 - 두 번째 이야기
; https://www.sysnet.pe.kr/2/0/521

sgen.exe의 사용법은 아쉽게도 .NET Core/5+ 대상의 어셈블리에는 통용되지 않습니다. 대신, 마이크로소프트는 이와 동등한 역할을 하는 Microsoft.XmlSerializer.Generator 패키지를 공개했는데요, 관련 문서에서도 이에 대해 자세하게 다루고 있습니다.

Using Microsoft XML Serializer Generator on .NET Core
; https://learn.microsoft.com/en-us/dotnet/core/additional-tools/xml-serializer-generator

간단하게 실습해 볼까요? ^^

.NET Core/5+ 라이브러리 프로젝트를 하나 생성하고 예제를 위한 클래스 하나를 정의해 둡니다.

public class Dummy
{
    public int Value { get; set; }
}

그다음, 해당 프로젝트에 nuget으로부터 Microsoft.XmlSerializer.Generator 패키지를 참조 추가합니다.

Install-Package Microsoft.XmlSerializer.Generator

끝입니다. ^^ 저걸 참조한 것만으로도 이제 빌드할 때마다 [어셈블리명].XmlSerializers.cs 파일이 자동 생성되고, 그것을 빌드한 [어셈블리명].XmlSerializers.dll 파일이 출력 폴더에 함께 생성됩니다.

Rebuild started...
1>------ Rebuild All started: Project: ClassLibrary1, Configuration: Debug Any CPU ------
Restored C:\temp\ConsoleApp1\ConsoleApp1\ConsoleApp1.csproj (in 1 ms).
Restored C:\temp\ConsoleApp1\ClassLibrary3\ClassLibrary3.csproj (in 1 ms).
Restored C:\temp\ConsoleApp1\ClassLibrary1\ClassLibrary1.csproj (in 2 ms).
Restored C:\temp\ConsoleApp1\ConsoleApp1\ConsoleApp1.csproj (in 1 ms).
1>ClassLibrary1 -> C:\temp\ConsoleApp1\ClassLibrary1\bin\Debug\net5.0\ClassLibrary1.dll
1>.NET Xml Serialization Generation Utility, Version 7.0.0]
1>Serialization Code File Name: C:\temp\ConsoleApp1\ClassLibrary1\obj\Debug\net5.0\ClassLibrary1.XmlSerializers.cs.
1>Generated serialization code for assembly C:\temp\ConsoleApp1\ClassLibrary1\obj\Debug\net5.0\ClassLibrary1.dll --> 'C:\temp\ConsoleApp1\ClassLibrary1\obj\Debug\net5.0\ClassLibrary1.XmlSerializers.cs'.
========== Rebuild All: 1 succeeded, 0 failed, 0 skipped ==========
========== Elapsed 00:01.089 ==========

오히려, 예전 sgen 관리 때보다 더 편해졌다고도 볼 수 있습니다. ^^




참고로, .NET Framework 버전의 sgen을 이용해 .NET Core/5+ 어셈블리를 인자로 실행하면 이런 오류가 발생할 것입니다.

c:\temp> where sgen
C:\Program Files (x86)\Microsoft SDKs\Windows\v10.0A\bin\NETFX 4.8 Tools\x64\sgen.exe

c:\temp> sgen Test.dll
Microsoft (R) Xml Serialization support utility
[Microsoft (R) .NET Framework, Version 4.8.3928.0]
Copyright (C) Microsoft Corporation. All rights reserved.
Error: Could not load file or assembly 'System.Runtime, Version=5.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a' or one of its dependencies. The system cannot find the file specified.

If you would like more help, please type "sgen /?".

또는, 해당 어셈블리로부터 아무런 타입도 찾을 수 없다는 메시지가 뜨기도 합니다.

c:\temp> sgen classlibrary3.dll
Microsoft (R) Xml Serialization support utility
[Microsoft (R) .NET Framework, Version 4.8.3928.0]
Copyright (C) Microsoft Corporation. All rights reserved.
Assembly 'C:\temp\ConsoleApp1\ClassLibrary3\bin\Debug\net7.0\classlibrary3.dll' does not contain any types that can be serialized using XmlSerializer. Please use /verbose switch for more information.




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 12/16/2022]

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

비밀번호

댓글 작성자
 




1  2  3  4  5  6  7  8  9  [10]  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13693정성태7/24/20247249개발 환경 구성: 717. Visual Studio - C# 프로젝트에서 레지스트리에 등록하지 않은 COM 개체 참조 및 사용 방법파일 다운로드1
13692정성태7/24/20248043디버깅 기술: 199. Windbg - 리눅스에서 뜬 닷넷 응용 프로그램 덤프 파일에 포함된 DLL의 Export Directory 탐색
13691정성태7/23/20247401디버깅 기술: 198. Windbg - 스레드의 Win32 Message Queue 정보 조회
13690정성태7/23/20247020오류 유형: 919. Visual C++ 리눅스 프로젝트 - error : ‘u8’ was not declared in this scope
13689정성태7/22/20248554디버깅 기술: 197. Windbg - PE 포맷의 Export Directory 탐색
13688정성태7/21/20247641닷넷: 2281. C# - Lock / Wait 상태에서도 일부 Win32 메시지 처리파일 다운로드1
13687정성태7/19/20248065닷넷: 2280. C# - PostThreadMessage로 보낸 메시지를 Windows Forms에서 수신하는 방법파일 다운로드1
13686정성태7/19/20247856오류 유형: 918. Visual Studio - ATL Simple Object 추가 시 error C2065: 'IDR_...': undeclared identifier
13685정성태7/19/20248017스크립트: 66. Windows 디렉터리 경로를 WSL의 /mnt 포맷으로 구하는 방법 - 두 번째 이야기
13684정성태7/19/20248191닷넷: 2279. C# - 문자열 보간식 사례 (예: 조건 연산자 사용)
13683정성태7/18/20247669오류 유형: 917. ClrMD - Linux 환경의 .NET 5 덤프 분석 시 hang 현상
13682정성태7/18/20247871닷넷: 2278. WPF - 스레드에 종속되는 DependencyObject파일 다운로드1
13681정성태7/17/20247485닷넷: 2277. C# 13 - (2) 메서드 그룹의 자연 타입 개선 (메서드 추론 개선)파일 다운로드1
13680정성태7/16/20247865닷넷: 2276. C# - Method Group, Natural Type, function_type파일 다운로드1
13679정성태7/16/20246947Linux: 76. Linux - C++ (getaddrinfo 등을 담고 있는) libnss 정적 링크
13678정성태7/15/20247086VS.NET IDE: 191. Visual Studio 2022 - .NET 5 프로젝트를 Docker Support로 실행했을 때 오류
13677정성태7/15/20247174오류 유형: 916. MSBuild - CheckEolTargetFramework (warning NETSDK1138)
13676정성태7/14/20247346Linux: 75. gdb에서 glibc의 함수에 Breakpoint 걸기
13675정성태7/13/20249137C/C++: 166. C/C++ - DLL에서 template 함수를 export하는 방법 [1]파일 다운로드1
13674정성태7/13/20248010오류 유형: 915. Unhandled Exception: Microsoft.Diagnostics.NETCore.Client.ServerNotAvailableException: Unable to connect to Process
13673정성태7/11/20248461닷넷: 2275. C# 13 - (1) 신규 이스케이프 시퀀스 '\e'파일 다운로드1
13672정성태7/10/20247170닷넷: 2274. IIS - (프로세스 종료 없는) AppDomain Recycle
13671정성태7/10/20247270오류 유형: 914. Package ca-certificates is not installed.
13669정성태7/9/20247388오류 유형: 913. C# - AOT StaticExecutable 정적 링킹 시 빌드 오류
13668정성태7/8/20247419개발 환경 구성: 716. Hyper-V - Ubuntu 22.04 Generation 2 유형의 VM 설치
13667정성태7/7/20246625닷넷: 2273. C# - 리눅스 환경에서의 Hyper-V Socket 연동 (AF_VSOCK)파일 다운로드1
1  2  3  4  5  6  7  8  9  [10]  11  12  13  14  15  ...