Microsoft MVP성태의 닷넷 이야기
글쓴 사람
kmi
홈페이지
첨부 파일
 

예를 들어 시리얼 포트를 통해 데이터를 주고 받는 프로그램이 있습니다. 이 프로그램에는 매우많은 전역변수 (거의 30~40개 가량) 가 있고 GC 는 따로 코드로 수행하지 않으며 타이머 또한 매우 많습니다. 그리고 타이머는 모두 윈폼 타이머 이며 false 였다가 작동하는 것이 몇 개 있고, 전역변수의 30% 는 string, 5% 는 다른 클래스에서 참조한 변수 (예 : Class class = new Class()), 25% 는 string[] 이며, 그 외는 int, int[], 쓰레드 변수 들이 있습니다. 통신시 데이터 처리 이후 초기화 하는 부분은 몇 군데에 존재합니다. (Remove() 사용)
또한, 포트는 시리얼 포트는 3개가 있고 1개만 송,수신을 하며 나머지 2개는 송신만 담당합니다.

위 프로그램에서 해당 현상이 발생되었을 때 해결하고 싶은데 메모리 부족 현상 원인으로 제가 알고 있는 것으로는 "GC 가 수집하지 못해서 메모리가 누적된다" 뿐입니다. 그래서 시도할 수 있는 방법이 제한적이에요.
위 프로그램의 원인 뿐만이 아니라 메모리 부족 현상의 다른 여러 가지 원인들도 알 수 있을까요 ?? 이런 현상이 발생하면 해결하고 싶은데 원인을 많이 알지 못해서 해결 방법이 한정적이라 답답합니다. ㅜㅜ








[최초 등록일: ]
[최종 수정일: 8/17/2017]


비밀번호

댓글 작성자
 



2017-08-17 04시25분
글쎄요. OOM 상황은 프로그램에서 인스턴스 객체를 전역 변수와 같은 곳에서 들고 있는 상황이 되면 GC가 수집할 수 없는 상황이 얼마든지 다양하게 나타나므로 딱히 이거다... 라고 말할 것이 없습니다.

해당 현상이 발생했을 때 procdump.exe와 같은 것을 이용해 일정 메모리 기준 이상이 되면 풀 덤프를 남기도록 해보세요. 아니면 프로그램 내부에서 메모리 체크를 하다가 스스로 남겨도 됩니다.

풀 덤프 파일을 남기는 방법
; http://www.sysnet.pe.kr/2/0/991

코드(C#)를 통한 풀 덤프 만드는 방법
; http://www.sysnet.pe.kr/2/0/995

덤프 분석을 해보면... 그래도 어느 정도는 답을 얻을 수 있을 것입니다.
정성태
2017-08-18 05시41분
[kmi] 답변 감사합니다. 한번 시도해보겠습니다.
[guest]

... 46  47  48  49  50  51  52  53  54  [55]  56  57  58  59  60  ...
NoWriterDateCnt.TitleFile(s)
1279(non...6/23/201411622(글쓴이의 요청으로 삭제합니다.) [17]
1278이상식6/19/201412840.net DLL 내 자바스크립트를 수정 또는 재정의 할 수 있을까요? [3]
1277김솔지6/18/201410534silverlight에서 datagrid, listbox질문이여 [2]
1276정우석6/16/201410054쿠키 [1]
1274김솔지6/10/201414535배포 페이지 url을 얻고 싶습니다. [8]
1272이훈모6/7/201410097정말 어려운 상황에 직면했습니다. [1]
1270Jong...6/2/201419560C#과 C++을 이용한 Image 처리. [13]
1269김아영5/29/201410240InitializeComponent 함수 호출 지연 현상 [5]
1268솔솔5/27/20149882smart client [1]
1266김솔지5/22/201411961clickonce 수정에 대해 알고싶습니다. [2]
1265이은아5/22/201415570DataGridView 헤더를 두줄이상으로 하고싶습니다. [1]파일 다운로드1
1264김인호5/18/201413173소스코드 및 예제그림 zip 파일 [1]
1263이영종5/15/201411611159페이지 오타인것 같습니다 [5]
1262(non...5/4/201412475(글쓴이의 요청으로 삭제합니다.) [10]
1261이근주5/4/201410782다시 한번 질문드릴께요. [2]
1259이근주5/1/20149825도서 오류인 것 같네요.. [1]
1258최세정4/28/201412237안녕하세요~php module 오류로 고민하다가 여기까지 왔네요..ㅜㅜ [2]
1252popo4/21/201411503바인딩 질문입니다. [2]
1251(non...4/20/201415623(글쓴이의 요청으로 삭제합니다.) [11]
1249홍용규4/17/201415628app.config 파일 관련 질문 있습니다. [2]
1246(non...3/30/201411947(글쓴이의 요청으로 삭제합니다.) [1]
1245POPO3/26/201411356Http 프로토콜 관련 질문 입니다. [1]
1244(non...3/26/201411461(글쓴이의 요청으로 삭제합니다.) [1]
1241(non...3/22/201415239(글쓴이의 요청으로 삭제합니다.) [4]
1240이석주3/21/201418140인터넷 익스플로러가 hang이 걸리는 현상 문의 [1]파일 다운로드1
1238(non...3/13/201411999(글쓴이의 요청으로 삭제합니다.) [2]
... 46  47  48  49  50  51  52  53  54  [55]  56  57  58  59  60  ...