Microsoft MVP성태의 닷넷 이야기
.NET Framework: 100. XML Serializer를 이용한 값 복사 [링크 복사], [링크+제목 복사],
조회: 25864
글쓴 사람
정성태 (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





XML Serializer를 이용한 값 복사


클래스의 복제 생성자를 작성하다 보면, 아래와 같은 식으로 값을 넣어주는 경우가 빈번하게 발생합니다.

public CopyClass(CopyClass inst)
{
  // 멤버 변수 값 복사 시작
  this.Name = inst.Name;
  this.Age = inst.Age;
  this.Type = inst.Type;
}

꼭 위와 같은 상황의 복제 생성자가 아니더라도, 코드상에서 흔히들 값 복제를 하기 위해 위와 같은 코드를 쭉 나열하는 경우를 볼 수 있는데요.

저 같은 경우에는, 특별히 속도를 중요시해야 하는 상황이 아니라면 다음과 같은 구문으로 해결을 하곤 합니다.

CopyClass org = new ...;
CopyClass inst = CloneData(org);

간단하지요. ^^

뭐 코드도 별거 없습니다. 다음과 같은 식으로 만들어 주면 됩니다.

public static TData CloneData<TData>(TData data) where TData : class
{
  if (data == null)
  {
    return null;
  }

  XmlSerializer xs = new XmlSerializer(typeof(TData));

  string serializedText = ObjectToString(xs, (TData)data);
  return (TData) StringToObject<TData>(serializedText);
}

public static string ObjectToString(object data)
{
  XmlSerializer xs = new XmlSerializer(data.GetType());
  return ObjectToString(xs, data);
}
    
public static string ObjectToString(XmlSerializer xs, object data)
{
  StringBuilder sb = new StringBuilder();
  StringWriter sw = new StringWriter(sb);
  XmlTextWriter writer = new XmlTextWriter(sw);

  xs.Serialize(writer, data);
  writer.Flush();

  return sb.ToString();
}

public static TData StringToObject<TData>(string text) where TData : class
{
  XmlSerializer xs = new XmlSerializer(typeof(TData));
  StringReader sr = new StringReader(text);
  XmlTextReader reader = new XmlTextReader(sr);

  return (TData)xs.Deserialize(reader);
}

XML로 직렬화시키면, 해당 문자열에는 인스턴스에서 가지고 있던 모든 값들이 문자열로 표현이 되어집니다. 그다음, 다시 그 문자열들을 가지고 인스턴스로 복원해 주면 끝!

참고로, 그나마 위의 코드를 좀 더 빠르게 하고 싶다면 다음의 토픽 정도는 한 번 더 읽어주셔야 겠지요. ^^

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

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



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

[연관 글]






[최초 등록일: ]
[최종 수정일: 6/27/2021]

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

비밀번호

댓글 작성자
 



2008-06-04 08시20분
[저예요... ^^] 어디서 많이 보던 소스군요...
그때가 잼있었는데.. 그쵸?

^^
[guest]
2008-06-05 08시18분
정환이형? ^^
kevin25
2012-12-05 12시56분
How to deep clone objects using reflection (CSDeepCloneObject)
; (broken) http://code.msdn.microsoft.com/CSDeepCloneObject-dfb03cb6
정성태
2013-01-28 01시22분
Deep clone the Entity objects using reflection [C#-Visual Studio 2012]
; (broken) http://code.msdn.microsoft.com/CSEFDeepCloneObject-12a5cb95
정성태
2016-08-18 12시26분
세상이 좋아져서, deep copy를 expression tree로도 하는군요. ^^

Fast Deep Copy by Expression Trees (C#)
; http://www.codeproject.com/Articles/1111658/Fast-Deep-Copy-by-Expression-Trees-C-Sharp
정성태

... 31  32  33  34  35  36  37  38  39  40  41  42  43  [44]  45  ...
NoWriterDateCnt.TitleFile(s)
12874정성태12/13/202114787오류 유형: 773. shell script 실행 시 "$'\r': command not found" 오류
12873정성태12/12/202116851오류 유형: 772. 리눅스 - PATH에 등록했는데도 "command not found"가 나온다면?
12872정성태12/12/202116845개발 환경 구성: 615. GoLang과 Python 빌드가 모두 가능한 docker 이미지 만들기
12871정성태12/12/202115746오류 유형: 771. docker: Error response from daemon: OCI runtime create failed
12870정성태12/9/202115333개발 환경 구성: 614. 파이썬 - PyPI 패키지 만들기 (4) package_data 옵션
12869정성태12/8/202117879개발 환경 구성: 613. git clone 실행 시 fingerprint 묻는 단계를 생략하는 방법
12868정성태12/7/202116556오류 유형: 770. twine 업로드 시 "HTTPError: 400 Bad Request ..." 오류 [1]
12867정성태12/7/202116225개발 환경 구성: 612. 파이썬 - PyPI 패키지 만들기 (3) entry_points 옵션
12866정성태12/7/202123151오류 유형: 769. "docker build ..." 시 "failed to solve with frontend dockerfile.v0: failed to read dockerfile ..." 오류
12865정성태12/6/202116540개발 환경 구성: 611. 파이썬 - PyPI 패키지 만들기 (2) long_description, cmdclass 옵션
12864정성태12/6/202114197Linux: 46. WSL 환경에서 find 명령을 사용해 파일을 찾는 방법
12863정성태12/4/202116247개발 환경 구성: 610. 파이썬 - PyPI 패키지 만들기
12862정성태12/3/202113943오류 유형: 768. Golang - 빌드 시 "cmd/go: unsupported GOOS/GOARCH pair linux /amd64" 오류
12861정성태12/3/202117956개발 환경 구성: 609. 파이썬 - "Windows embeddable package"로 개발 환경 구성하는 방법 [1]
12860정성태12/1/202114008오류 유형: 767. SQL Server - 127.0.0.1로 접속하는 경우 "Access is denied"가 발생한다면?
12859정성태12/1/202122374개발 환경 구성: 608. Hyper-V 가상 머신에 Console 모드로 로그인하는 방법
12858정성태11/30/202119766개발 환경 구성: 607. 로컬의 USB 장치를 원격 머신에 제공하는 방법 - usbip-win
12857정성태11/24/202116311개발 환경 구성: 606. WSL Ubuntu 20.04에서 파이썬을 위한 uwsgi 설치 방법
12856정성태11/23/202119120.NET Framework: 1121. C# - 동일한 IP:Port로 바인딩 가능한 서버 소켓 [2]
12855정성태11/13/202114343개발 환경 구성: 605. Azure App Service - Kudu SSH 환경에서 FTP를 이용한 파일 전송
12854정성태11/13/202116450개발 환경 구성: 604. Azure - 윈도우 VM에서 FTP 여는 방법
12853정성태11/10/202114924오류 유형: 766. Azure App Service - JBoss 호스팅 생성 시 "This region has quota of 0 PremiumV3 instances for your subscription. Try selecting different region or SKU."
12851정성태11/1/202116631스크립트: 34. 파이썬 - MySQLdb 기본 예제 코드
12850정성태10/27/202118399오류 유형: 765. 우분투에서 pip install mysqlclient 실행 시 "OSError: mysql_config not found" 오류
12849정성태10/17/202118011스크립트: 33. JavaScript와 C#의 시간 변환 [1]
12848정성태10/17/202117148스크립트: 32. 파이썬 - sqlite3 기본 예제 코드 [1]
... 31  32  33  34  35  36  37  38  39  40  41  42  43  [44]  45  ...