Microsoft MVP성태의 닷넷 이야기
파일 저장 방법에 대해 조언 부탁드립니다. [링크 복사], [링크+제목 복사],
조회: 7473
글쓴 사람
C#초보
홈페이지
첨부 파일
 

안녕하세요. 현재 제가 만들고 있는 프로그램에서 어떤 방식으로 파일을 저장해야 좋을지에 대해 조언을 부탁드리고 싶습니다.

이 프로그램은 평일에 계속 시계열 자료를 받는 용도로 만들고 있습니다.

인덱스값, 발생시각, 자료값들 중에서 인덱스 값을 제외한 모든 값을 string 형태로 받고 있습니다.

중간에 자료형을 변환하는 비용을 없애기 위해, 자료 수신시마다 자료형 변환 없이 구조체를 사용해서 리스트 안에 이 구조체를 저장하고 있습니다.

기존에는 이렇게 리스트에 자료값이 든 구조체를 저장하다가, 구조체의 수가 특정 수(50이나 100)가 되면

csv형태로 디스크에 append하고(for loop 이용), 해당 리스트는 Clear()로 다시 비웠습니다.

그런데 Serialization에 대해 알게 되어서, 이걸 이용해서 자료를 디스크에 쓰게 되면 훨씬 더 효율적일 수 있다는 생각이 들었습니다.

저는 단순히 디스크에 저장할 용도로 사용하길 바라기 때문에 BinaryFormatter를 사용해 볼까 하는데요.

이게 제가 설명드린 사용 목적 - 실시간으로 받은 자료를 중간 중간 이어서 디스크의 동일 파일에 저장 - 에 부합하는 방법일까요?

가능은 하겠지만, 이게 과연 표준적으로 사용하는 방법인지, 퍼포먼스적인 관점에서 더 나은 방법이 있는지 조언을 얻고 싶습니다.








[최초 등록일: ]
[최종 수정일: 11/10/2019]


비밀번호

댓글 작성자
 



2019-11-10 07시30분
지금 csv 형태로 쓰고 있던 그것도 일종의 수동 serialization이라고 보면 됩니다. .NET BCL에서 자동으로 해주는 Serialization은 그 과정을 Reflection 등의 정보를 통해 자동화하는 것 뿐입니다.

따라서 BinaryFormatter로 바꾸시면 동일한 목적을 이룰 수 있습니다. 하지만, 성능이나 저장 공간 측면에서 보면 기존에 비해 만족스럽진 않을 것입니다. 왜냐하면 직렬화 시 데이터의 크기라든지 타입 등의 정보도 함께 출력이 되기 때문에 다소 늘어날 수 있습니다. (이 부분은 약간의 샘플 데이터로 테스트해 해보세요.)

제 생각에는 현재 인덱스를 제외한 각 자료값들의 타입 정보가 크게 중요하지 않고 데이터들의 내용이 CSV를 써도 될 만큼 간단한 것 같은데, 그렇다면 그냥 기존의 방식을 쓰시는 것도 나쁘지 않은 선택으로 보입니다.
정성태
2019-11-10 11시03분
[C#초보] 조언해 주셔서 감사합니다.
네, 말씀하신대로 실제 데이터를 넣어서 바이너리로 저장을 하니까 용량이 꽤 되네요. 아무래도 이 방법도 사용하기는 힘들 듯합니다.
제가 걱정되는 부분은 csv로 파일 쓰기 반복문이 실행되는 사이에 수신되는 데이터를 놓치는 부분인데요. 이 부분은 고민을 좀 해 봐야겠네요.
[guest]
2019-11-11 08시42분
얼마나 수신 데이터가 많은지는 모르겠지만, 그렇다면 쓰기 처리를 하는 부분을 별도의 스레드로 분리하면 되지 않을까요? 50~100개가 list에 담기면 그 리스트 인스턴스를 Queue에 저장하고 이후의 데이터는 새로운 list에서 담도록 만들고 Queue에 담긴 것은 다른 스레드에서 쓰기 처리를 하면 될 것입니다.
정성태

... 46  47  48  49  50  51  52  53  [54]  55  56  57  58  59  60  ...
NoWriterDateCnt.TitleFile(s)
1306이상현8/7/201410024Entity 프레임웍에서 테이블만 추가로 등록하는 방법
1307이상현8/7/201410326    답변글 [답변]: 자답이네요. [1]
1305popo8/7/201411572wpf UserControl List 바인딩 질문 입니다. [1]
1304민경수8/7/201414146네이버 카페에 구글 스프레드 시트 삽입 [1]
1303김동진8/7/201411386vmware환경에서 Guest IP를 192대역으로 받을 수 있는 방법은 없을까요~? [3]
1302김문경7/31/201410529스마트클라이언트 오라클 연결 [1]
1314이재균8/20/201410579    답변글 [답변]: 스마트클라이언트 오라클 연결
1300아로스7/28/201423440c# 인터넷 임시 파일 삭제 문의 [12]파일 다운로드1
1299서동원7/28/201412036안녕하세요. 혹시 Internet_Zone과 관련된문제인가 해서 질문드립니다. [1]
1298(non...7/25/201417415(글쓴이의 요청으로 삭제합니다.) [15]
1295서동원7/22/201413119안녕하세요. 스마트클라이언트에 대해 질문드립니다. [2]파일 다운로드1
1294(non...7/20/201411505(글쓴이의 요청으로 삭제합니다.) [2]
1293VS20...7/20/201412071VS2013 Ultimate에 Windows Phone 프로젝트 템플릿 추가 방법 문의 [1]파일 다운로드2
1292(non...7/20/201410839(글쓴이의 요청으로 삭제합니다.) [2]
1291zino7/16/201411429chromium 배포본 만들기~ [1]
1290(non...7/13/201412595(글쓴이의 요청으로 삭제합니다.) [3]
1288박주만7/8/201421754C# 서비스 기반 데이터베이스(mdf) & InstallShield Limited Edition 설치 및 배포 [2]파일 다운로드1
1287김용환7/8/201419754오라클 db 사용관련 문의입니다. [4]파일 다운로드1
1286C#조으다7/8/201410712WebBrowser 공유기 관리 웹 페이지 인증 [3]
1285C#조으다7/5/201411045IE DocumentComplete 이벤트가 발생되지 않습니다. [2]
1284(non...7/4/201411207(글쓴이의 요청으로 삭제합니다.) [3]
1283김영대7/3/201414297안녕하십니까 정성태님 죄송하지만 SmartClient 에 관한 질문이 있습니다. [9]
1282(non...7/2/201411164(글쓴이의 요청으로 삭제합니다.) [2]
1281(non...7/1/201412271(글쓴이의 요청으로 삭제합니다.) [4]
1280동동이6/25/201411474안녕하세요. ocx의 비동기 또는 쓰레드에서 호출 [1]
1279(non...6/23/201411550(글쓴이의 요청으로 삭제합니다.) [17]
... 46  47  48  49  50  51  52  53  [54]  55  56  57  58  59  60  ...