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]

1  2  [3]  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
5912guest4/25/202316759[참고 - 초보용] Sqlite 디비는 double이 없고 Real이 대신합니다 [3]
5911guest4/24/202311524Form1.cs와 외부 class.cs와 통신 (static async method포함) [4]파일 다운로드1
5910guest4/24/202310997Async 메서드와 try~catch [1]
5909guest4/22/202312002Visual Studio 구매 시(1인 개발자) [4]
5908guest4/22/202311680텅빈 원그리기 [5]
5907민성4/21/202311176안녕하세요 서버 백업 문제에 대해서 [2]
5906guest4/21/202311551Dispatcher 서비스 구현 질문 [1]
5905guest4/20/202312552tabControl의 tabPage가 여러 개일 때 순서를 바꾸기가 까다롭네요 [5]
5904guest4/18/202312483[신규자료첨부] DLL 'SQLite.Interop.dll'을 찾을 수 없습니다 [4]파일 다운로드1
5903guest4/18/202311225fileSystemWatcher 이벤트 관련 질문입니다 [2]
5902guest4/17/202312324c#으로 USB 관련 질문 [2]
5901guest4/17/202310634내솔루션 판매 시 1.0.0.0 폴더와 Sqlite 배포 [5]
5900guest4/17/202312698DLL 'SQLite.Interop.dll'을 찾을 수 없습니다 [2]파일 다운로드1
5899guest4/17/202311364Dictionary와 Linq [4]
5898차가워4/17/202311364CNTK 교육 문의 [1]
5897guest4/17/202311112Socket스레드와 UI thread [4]
5896HAN4/16/202310990c언어 return 에 대해 궁금한게 있어요. [1]파일 다운로드1
5895guest4/15/202311304Drag and Drop - 모든 컨트롤 [2]
5894송부장4/14/202312834[질문] Visual Studio 2022에서 '도구 상자 항목 선택'의 'COM 구성 요소' 탭에서 ActiveX 목록이 보이지 않습니다. [3]파일 다운로드2
5893감사합니...4/14/202310916오라클 OLEDB방식 접속 후 SELECT 'TEST' TEST_VALUE FROM DUAL의 값이 이상합니다. [1]
5892한무4/14/202310854C# 으로 백그라운드에서 워드를 실행하여 매크로 실행이 가능 할까요? [2]
5891리세4/14/202311663안녕하세요.C# 서버프로그램에서의 Mysql 쿼리문제(다중쿼리 실행)에 대해 문의드립니다. [2]
5890guest4/14/202312566C# 프리랜서로 돈 벌려면 성태님 책 마스터하면 되나요? [6]
5889전예찬4/14/202310902C# 파일 복사 관련 질문 드립니다. [3]
5888정경구4/12/202311011C# 첫 환경 세팅과 관련해서 [4]
5887HAN4/12/202311101안녕하세요 파이썬도 공유 가능 할까요? [1]
1  2  [3]  4  5  6  7  8  9  10  11  12  13  14  15  ...