Microsoft MVP성태의 닷넷 이야기
글쓴 사람
nalsandori (nalsandori at gmail.com)
홈페이지
첨부 파일
※ 현재 vs2013이 설치되지 않아 설치 후 정상 컴파일 확인 후 공유 드립니다.
※ 첨부파일
  - vs2013에서 사용한 프로젝트 파일
  - bin/debug 폴더 내 test.dat 파일 있음

 아래는 Sample Code 입니다.
원인이 무엇인지 찾다보니 아래 소스 구현하여 재현하였습니다

#현상
  - vs2013에서 프로그램 컴파일 후 Serialize 후 Deserialize할 경우 정상 동작 함
  - vs2015로 마이그레이션 하고자 동일한 프로젝트 오픈 후 실행시 vs2013에서 Serialize로 생성한 파일 Deserialize 할 경우 예외 발생
    . Exception Message
      : 해당 개체 멤버를 가져올 수 없습니다
#원인
  - vs2013에서 Serialize 후 test.dat 파일 생성
  - vs2015에서 동일한 프로젝트 오픈 후 아래 SerializeObj 주석 후 Deserialize() 호출시 예외 발생
  - test.dat 파일 중 <CreateRules>b__0 멤버를 가져올 수 없습니다
    : vs2015에선 <CreateRules>b__31_0으로 Serialize 함
    : 같은 코드로 실행시 전반적으로 vs2013, 2015 serialize 시도시 일부 format이 상이 함

#질문
  - 왜 이런 현상이 발생한건가요?
    : 같은 .net 버전 사용 중 입니다
    : BinaryFormatter 버전으로 인한 건가요?
  - visual studio 하위 버전이라 간만에 상위 버전으로 마이그레이션 시도하였습니다
    vs2015로 우선 테스트 후 가능하면 최근 버전으로 사용하고자 합니다
    : 이럴 경우 기존 vs2015 사용 후 2018, 2019에도 동일한 현상이 발생하는 건 아닌가요?


[연관 글]






[최초 등록일: ]
[최종 수정일: 2/27/2020]


비밀번호

댓글 작성자
 



2020-02-27 01시44분
다음의 글을 참고하세요.

익명 함수를 가리키는 delegate 필드에 대한 직렬화 문제
; https://www.sysnet.pe.kr/2/0/12163
정성태
2020-02-27 08시17분
[guest] 자세한 설명 정말 감사합니다.
많은 도움이 됐습니다.
결국, BinaryFormatter.Serialize할 때 익명함수 포함시 유지보수 하기 어려운 점이 있겠군요.
이해 안되는 점이 익명함수 직렬화시 네이밍 룰은 프레임워크 버전이 변경되어도 계속 유지해도 될 듯 한데
왜 이런 문제의 여지를 남겨 둔건지 난감합니다.
 예제에서 말씀 드렸드시 test.dat 파일은 여러 사람이 사용하는 중이라...
그래도 지적하신대로 기존 데이터를 우선 포기하는 방향으로 잡을 예정입니다.
감사합니다

[손님]
2020-02-27 09시08분
사실 그런 경우는 여지를 남겨두었다기보다는 사용한 측에서의 오류라고 봐야 합니다. 익명 함수는 말 그대로 이름이 없는 것이고, 내부적인 작명 규칙을 정해서 공표한 것도 아니므로 언제 어떻게 바뀐다고 이상할 게 없습니다.

게다가, 직렬화하는 경우였다면 delegate 필드 자체의 값을 포함시키기보다는 해당 delegate를 식별할 수 있는 고유 id를 정해 그 값을 직렬화하는 것이 바람직합니다.
정성태

1  2  3  4  5  6  7  8  9  10  [11]  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
5399Wpf개발중10/21/20202352Binding 된 항목의 갱신 시 간헐적 끊어짐 발생 문제. [2]
5397나그네10/15/20202077.net Core 3.1 에서 Entity Framework 와 ADO.NET 선택에 관해 여쭤봅니다. [2]
5396여정욱10/15/20202159CLR heap 관련 질문 2 [2]
5395여정욱10/14/20202489CLR heap 관련 질문 [2]
5394진우10/12/20204701닷넷코어 (닷넷5) winform wpf는 리눅스/맥에서도 가능한가요? [2]
5393김세용9/23/20203029C#에서 대량의 클래스를 빠르게 생성하는 방법이 없을까요? [6]
5392전경호9/22/20202367WPF에서 WindowsFormsHost의 메모리 누수 문제 때문에 문의드립니다. [1]파일 다운로드1
5391민성9/22/20202432안녕하세요 항상 감사드립니다. 하나 질문 드리겠습니다. [1]
5390alower9/18/20203341System.AccessViolationException 보호된메모리 부분 예외처리 [1]
5389C# 8.0 구매자9/18/20202708후위 증감 연산자 오버로딩 방법 좀 알려주세요 [4]
5388영귤9/17/20202936Nullable reference type 에 Non-nullable reference type 을 대입해도 경고가 발생하지 않습니다. [2]
5387하태9/17/20202564안녕하세요! 비동기 통신과 관련하여 질문하나만 드리겠습니다! [3]
5386박민웅9/16/20203024정성태 스승님 안녕하세요 !! [1]
5385영귤9/12/202023023항 연산자에 ref 지원? [1]
5384손님9/10/20202047시작하세요! C# 8.0 프로그래밍 책에 오타가 있는 것 같습니다. [3]
5383민성9/8/20202775안녕하세요 자주 도움을 주셔서 감사드립니다. WPF에서 크롬 브라우저 삽입에 대하여 [1]
5382정씨9/4/20202832[C#] 시리얼통신 수신된 데이터를 그리드뷰에 뿌르는데 일정 시간이 지나면 버벅 거리는 이유가 뭘까요?? [3]
5381질문 있어요9/4/20202746웹으로 사용하는 c#과 응용프로그램으로 사용하는 c#이 많이 다른가요?? [2]
5380yeon9/3/20202476winform 의 datagridview는 바인딩이 안 되나요? [1]
5379손님9/2/20203103시작하세요! C# 8.0 프로그래밍 책에 오타가 있습니다. [3]
5378net9/2/20202594mes 응용프로그램을 .net 웹폼으로 만들기도 하나요? [2]
5377net9/2/20202419.net 사용한 웹폼으로 응용프로그램을 만들경우 [1]
5376영귤9/1/20202650nullable 타입간의 비교연산은 그냥 가능한 건가요? [1]
5375영귤8/30/20203493이벤트와 델리게이트의 차이가 궁금합니다. [2]
5374손님8/27/20203401시작하세요! C# 8.0 프로그래밍 책에 오타가 있습니다. [1]
5373agj8/26/20202495System.Single::ToString()함수의 IL코드를 보았는데 ldnull, throw가 전부입니다. 왜 이렇게 짧죠? [2]
1  2  3  4  5  6  7  8  9  10  [11]  12  13  14  15  ...