Microsoft MVP성태의 닷넷 이야기
글쓴 사람
김현준 (munga0828 at naver.com)
홈페이지
첨부 파일
 

안녕하세요?
Datagridview를 통해서 100만개정도의 데이터를 출력시키는 프로그램을 작성하였습니다.
프로그램 사용하는데 있어서 큰 지장은 없지만 약간의 버벅임이 존재하여 확인해본 결과 스크롤시에 GC를 매우 여러번 호출하는 현상을 발견하였습니다.
Virtual Mode를 사용하여 Cellvalueneeded 이벤트를 통해 기존에 존재하는 배열의 인덱스를 참조하여 gridview의 셀에다가 데이터를 넣기만 하는데 GC를 왜이렇게 많이 호출하는지 궁금합니다.
(제 생각에는 매모리 할당 해제가 일어나지 않을것같거든요,.,)

제가 작성한 코드는 아래와 같습니다.
여러번 확인했는데 문제될것은 없어 보이는데.. 혹시 조금 더 효율적인 방법이 있나요?

private void Form1_CellValueNeeded(object sender, DataGridViewCellValueEventArgs e)
        {
            if (e.RowIndex >= ListCF.Count)
            {
                return;
            }

            DataGridView dgv = (DataGridView)sender;

            if (dgv.SelectedCells.Count == 1)
            {
                if (e.RowIndex == dgv.SelectedCells[0].RowIndex && e.ColumnIndex == 0)
                {
                    dgv.Rows[e.RowIndex].DefaultCellStyle.BackColor = Color.LightSkyBlue;
                }
                else if (e.ColumnIndex == 0)
                {
                    dgv.Rows[e.RowIndex].DefaultCellStyle.BackColor = Color.White;
                }
            }
            else
            {
                dgv.Rows[e.RowIndex].DefaultCellStyle.BackColor = Color.White;
            }

            if (dgv.Name == DGV[(int)DGV_DEVICE.CF190].Name)
            {

                switch (e.ColumnIndex)
                {
                    case (int)DGV_HEADER_CF190.NO:
                        e.Value = e.RowIndex + 1;
                        break;
                    case (int)DGV_HEADER_CF190.NAME:
                        if (ListCF[e.RowIndex].rawData_64 == 0xF000000000000000 || ListCF[e.RowIndex].rawData_64 == 0)
                        {
                            e.Value = "-";
                        }
                        else if (DeviceDataInfo[(int)DGV_DEVICE.CF190].ContainsKey(ListCF[e.RowIndex].instructionInt))
                        {
                            e.Value = (DeviceDataInfo[(int)DGV_DEVICE.CF190][ListCF[e.RowIndex].instructionInt].InstName);
                        }
                        else
                        {
                            e.Value = "Instruction ERR";
                        }
                        break;
                    case (int)DGV_HEADER_CF190.INSTRUCTION_s:
                        e.Value = ListCF[e.RowIndex].siSnsrInst65;
                        break;
                    case (int)DGV_HEADER_CF190.BIT13__9:
                        e.Value = ListCF[e.RowIndex].siSnsrBit13__9;
                        break;
                    case (int)DGV_HEADER_CF190.PARITY_s:
                        e.Value = ListCF[e.RowIndex].siSnsrParity;
                        break;
                    case (int)DGV_HEADER_CF190.BIT7__4:
                        e.Value = ListCF[e.RowIndex].siSnsrBit7__4;
                        break;
                    case (int)DGV_HEADER_CF190.DATA_IN_s:
                        e.Value = ListCF[e.RowIndex].siSnsrData;
                        break;
                    case (int)DGV_HEADER_CF190.TFF_s:
                        e.Value = ListCF[e.RowIndex].soSnsrTFF;
                        break;
                    case (int)DGV_HEADER_CF190.TST_s:
                        e.Value = ListCF[e.RowIndex].soSnsrTST;
                        break;
                    case (int)DGV_HEADER_CF190.EOP_s:
                        e.Value = ListCF[e.RowIndex].soSnsrEOP;
                        break;
                    case (int)DGV_HEADER_CF190.SID:
                        e.Value = ListCF[e.RowIndex].soSnsrSID;
                        break;
                    case (int)DGV_HEADER_CF190.DATA_Out_s:
                        e.Value = ListCF[e.RowIndex].soSnsrOutputData;
                        break;
                    case (int)DGV_HEADER_CF190.INSTRUCTION_m:
                        e.Value = ListCF[e.RowIndex].siMdulInstruction;
                        break;
                    case (int)DGV_HEADER_CF190.PARITY_m:
                        e.Value = ListCF[e.RowIndex].siMdulParity;
                        break;
                    case (int)DGV_HEADER_CF190.DATA_IN_m:
                        e.Value = ListCF[e.RowIndex].siMdulInputData;
                        break;
                    case (int)DGV_HEADER_CF190.TFF_m:
                        e.Value = ListCF[e.RowIndex].soMdulTFF;
                        break;
                    case (int)DGV_HEADER_CF190.TST_m:
                        e.Value = ListCF[e.RowIndex].soMdulTST;
                        break;
                    case (int)DGV_HEADER_CF190.EOP_m:
                        e.Value = ListCF[e.RowIndex].soMdulEOP;
                        break;
                    case (int)DGV_HEADER_CF190.BIT12__11:
                        e.Value = ListCF[e.RowIndex].soMdulBit12__11;
                        break;
                    case (int)DGV_HEADER_CF190.WDF:
                        e.Value = ListCF[e.RowIndex].soMdulWDF;
                        break;
                    case (int)DGV_HEADER_CF190.BIT9__8:
                        e.Value = ListCF[e.RowIndex].soMdulBit9__8;
                        break;
                    case (int)DGV_HEADER_CF190.DATA_OUT_m:
                        e.Value = ListCF[e.RowIndex].soMdulData;
                        break;

                }
            }
        }








[최초 등록일: ]
[최종 수정일: 7/3/2017]


비밀번호

댓글 작성자
 



2017-07-03 01시37분
위의 코드만 봐서는 구현상 문제는 없어 보이는데요. 스크롤할 때 Form1_CellValueNeeded 코드만 실행되는 것이 맞나요? 아래의 예제 코드로도 100만개 리스트면 재현이 되나요?

How to: Implement Virtual Mode in the Windows Forms DataGridView Control
; https://docs.microsoft.com/en-us/dotnet/framework/winforms/controls/how-to-implement-virtual-mode-in-the-windows-forms-datagridview-control
정성태
2017-09-16 08시13분
[1] 이벤트 시작 부분의 데이터그리드뷰 생성 부분에 넘어온 구리드 객체를 바로 타입변환을 하지마시고 new 로 생성 후 적용하세요
[guest]

... 46  47  48  49  50  51  52  53  54  55  [56]  57  58  59  60  ...
NoWriterDateCnt.TitleFile(s)
1238(non...3/13/201411987(글쓴이의 요청으로 삭제합니다.) [2]
1237(non...3/11/201412089(글쓴이의 요청으로 삭제합니다.) [2]
1236(non...3/11/201412977(글쓴이의 요청으로 삭제합니다.) [2]
1235(non...3/10/201412123(글쓴이의 요청으로 삭제합니다.) [2]
1234(non...3/10/201414144(글쓴이의 요청으로 삭제합니다.) [3]
1233(non...3/9/201412274(글쓴이의 요청으로 삭제합니다.) [4]
1232(non...3/8/201411338(글쓴이의 요청으로 삭제합니다.) [2]
1231(non...3/7/201412644(글쓴이의 요청으로 삭제합니다.) [9]
1230POCO3/7/201412996쓰레드 안에서 DependencyProperty get, set시 또 다른 스레드 오류.. [1]
1229(non...3/6/201412729(글쓴이의 요청으로 삭제합니다.) [11]
1228POCO3/6/201411240안녕하세요. 질문이 있습니다. [1]
1226김형진3/4/201419817안녕하세요 windows azure에 관해 질문했던 사람입니다. [2]
1224(non...3/3/201415952(글쓴이의 요청으로 삭제합니다.) [11]
1223sadf...3/3/201411535아래 질문에 답변 감사드립니다. 한가지 더 궁금한점이 있어 질문드립니다. [1]
1222(non...3/2/201412389(글쓴이의 요청으로 삭제합니다.) [4]
1221(non...3/1/201412435(글쓴이의 요청으로 삭제합니다.) [2]
1220Until2/28/201410963질문드립니다. [1]
1219이성환2/28/201410648string.Join()과 Enumerable.Aggregate()의 차이가 궁금합니다. [2]파일 다운로드1
1218김형진2/25/201412107안녕하세요. window azure에 대해서 질문이 있어서 문의 드립니다 [4]
1217(non...2/23/201412553(글쓴이의 요청으로 삭제합니다.) [1]
1215아리수2/20/201416098C# 공부하면서 WPF에 대한 질문. [2]
1214조광훈2/20/201414343IIS8 응용프로그램 풀 관련 질문 드립니다. [2]파일 다운로드1
1213김태훈2/17/201411245가상화 프로그램 질문입니다. [1]파일 다운로드1
1212조광훈2/13/201410398ISAPI 필터에서 커스텀 헤더 정보 추가 [1]파일 다운로드1
1211조광훈2/12/201413813isapi 필터 로드 오류 [2]
1208박지호2/9/201417162[오타] 시작하세요 C# 프로그래밍 p.267 ~ 350 [1]
... 46  47  48  49  50  51  52  53  54  55  [56]  57  58  59  60  ...