Microsoft MVP성태의 닷넷 이야기
vs2013에서 BinaryFormatter Serialize 후 vs2015에서 Deserialize시 예외 발생 [링크 복사], [링크+제목 복사],
조회: 16246
글쓴 사람
nalsandori (nalsandori at gmail.com)
홈페이지
첨부 파일
(연관된 글이 1개 있습니다.)

※ 현재 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 파일은 여러 사람이 사용하는 중이라...
그래도 지적하신대로 기존 데이터를 우선 포기하는 방향으로 잡을 예정입니다.
감사합니다
[guest]
2020-02-27 09시08분
사실 그런 경우는 여지를 남겨두었다기보다는 사용한 측에서의 오류라고 봐야 합니다. 익명 함수는 말 그대로 이름이 없는 것이고, 내부적인 작명 규칙을 정해서 공표한 것도 아니므로 언제 어떻게 바뀐다고 이상할 게 없습니다.

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

... 91  92  [93]  94  95  96  97 
NoWriterDateCnt.TitleFile(s)
133김용국4/1/200510790                답변글 [답변]: [답변]: [답변]: [답변]: SmartClient 배포와 관련해서 무엇이 빠졌는지 좀 알려주시면 감사하겠습니다....!
126구정모3/31/200512088이홈의 효과는 어떻게???
128정성태3/31/200511235    답변글 [답변]: 이홈의 효과는 어떻게???
124배재현3/30/200511059Smart Client 문제로 이렇게 질문을 하나 올리게 됐습니다.^^;;
125정성태3/30/200510703    답변글 [답변]: Smart Client 문제로 이렇게 질문을 하나 올리게 됐습니다.^^;;
121안연준3/23/200510470이벤트 관련 문제
122정성태3/23/200510363    답변글 [답변]: 이벤트 관련 문제
120안연준3/23/200510301정성태님.... 오프라인 문제 질문 입니다. [1]
123정성태3/23/200510527    답변글 [답변]: 정성태님.... 오프라인 문제 질문 입니다. [1]
117정준명3/21/200511418COM+ 메소드 작성시...
118정성태3/29/200510975    답변글 [답변]: COM+ 메소드 작성시... [1]
109김용국3/18/200511969IE에 Docking된 WinFormControl내의 특정 메소드에 값을 보내기 .. 잘 되기는 하는데 한가지 문제가 ...
112정성태3/19/200511117    답변글 [답변]: IE에 Docking된 WinFormControl내의 특정 메소드에 값을 보내기 .. 잘 되기는 하는데 한가지 문제가 ...
113김용국3/19/200511063        답변글 [답변]: [답변]: IE에 Docking된 WinFormControl내의 특정 메소드에 값을 보내기 .. 잘 되기는 하는데 한가지 문제가 ...
114정성태3/19/200511076            답변글 [답변]: [답변]: [답변]: IE에 Docking된 WinFormControl내의 특정 메소드에 값을 보내기 .. 잘 되기는 하는데 한가지 문제가 ...
115김용국3/21/200510497                답변글 [답변]: [답변]: [답변]: [답변]: IE에 Docking된 WinFormControl내의 특정 메소드에 값을 보내기 .. 잘 되기는 하는데 한가지 문제가 ... [1]
119김용국3/22/200510460                    답변글 [답변]: 정상태님 아주 잘 해결 되었습니다.... 감사합니다!
108guest3/17/200510609닷넷 프레임워크 배포
111정성태3/19/200511130    답변글 [답변]: 닷넷 프레임워크 배포
107안연준3/17/200510296[-_-]스마트 클라이언트에 관련 된 질문[-_-]
110정성태3/19/200511228    답변글 [답변]: [-_-]스마트 클라이언트에 관련 된 질문[-_-]
116안연준3/21/200510610        답변글 [답변]: 친절한 답변 고맙습니다.
98김용국3/18/200512508정성태님... 연결이 준비됬습니다
99정성태3/2/200513437    답변글 [답변]: 정성태님... 연결이 준비됬습니다
100김용국3/18/200510399        답변글 [답변]: 죄송합니다! 급히올리느라 file path의 변경을 하지않고 그냥올렸네요....!
101정성태3/2/200510605            답변글 [답변]: [답변]: 죄송합니다! 급히올리느라 file path의 변경을 하지않고 그냥올렸네요....!
... 91  92  [93]  94  95  96  97