Microsoft MVP성태의 닷넷 이야기
파일 저장 방법에 대해 조언 부탁드립니다. [링크 복사], [링크+제목 복사]
조회: 7224
글쓴 사람
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에 담긴 것은 다른 스레드에서 쓰기 처리를 하면 될 것입니다.
정성태

[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
5932EK4/12/2024389다음 제네릭에서 널익셉션이 뜨는 이유를 알수있을까요? [1]
5931이대희4/2/2024763Windows 앱 SDK C# 템플릿의 용도가 무엇인지요? [1]
5930vict...2/22/20241690ef core, FromSqlRaw 맵핑 질문입니다. [4]
5929a2/17/20241786.Net 8 에서 디버거 변경 [1]
5928vict...2/5/20241940wpf에서 대량 데이터 보여주는 방법 추천 부탁드립니다. [1]
5926엄태영1/12/20241908잘못된 Task 사용으로 인한 데드락 관련 질문 입니다. [3]
5925Euni...12/22/20231851Visual Studio에서 nodejs 사용시 npm install -g @vue/cli 실행시 오류 [1]
5924Euni...12/21/20231920Visual Studio에서 nodejs 사용시 C:\Program Files\nodejs\\node.exe" "C:\Program Files\nodejs\\node_modules\npm\bin\npm-cli.js" prefix -g 를 찾지 못하는 설치 오류 [2]
5923정두호12/4/20232378MSSQL 데이터 전송과 공유폴더의 데이터 전송 차이점 [1]
5922Heeg...10/27/20234589C++의 double pointer를 C#에서 구현하는 방법이 잘 안됩니다. [3]
5921한예지 donator10/3/20234385마샬링 정의 및 목적이 궁금합니다. [5]
5920한예지 donator10/3/20233194C#과 WIN32 API 관계 질문드립니다. [4]
5919이건우9/27/20232894WinForm의 로딩속도 관련 질문입니다 [2]
5917한예지 donator9/14/20232981동기화 도구 질문 있습니다. [4]
5916한예지 donator9/3/20233136Thread.Sleep(500), await Task.Delay(500), Task.Delay(500) 차이점이 궁금합니다. [2]
5915한예지 donator8/30/20233054비동기 코드를 for 문 안에 작성한 경우 제어 변수가 올바르게 동작하지 않는 이유가 궁금합니다. [3]
5914한상욱8/11/20232872.net wpf에서 skiasharp 의 skelement 를 canvas로 사용 하고 있습니다. [1]
5913김태우8/10/20232956지역변수로 이해하는 메서드매개변수 게시글 댓글 [3]
5912guest4/25/20235120[참고 - 초보용] Sqlite 디비는 double이 없고 Real이 대신합니다 [3]
5911guest4/24/20233470Form1.cs와 외부 class.cs와 통신 (static async method포함) [4]파일 다운로드1
5910guest4/24/20233324Async 메서드와 try~catch [1]
5909guest4/22/20233707Visual Studio 구매 시(1인 개발자) [4]
5908guest4/22/20233573텅빈 원그리기 [5]
5907민성4/21/20233204안녕하세요 서버 백업 문제에 대해서 [2]
5906guest4/21/20233336Dispatcher 서비스 구현 질문 [1]
[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...