Microsoft MVP성태의 닷넷 이야기
글쓴 사람
kmi
홈페이지
첨부 파일
 
현재 어떤 기능을 쓰레드로 가동하고 있습니다.

해당 기능의 코드입니다.

IEnumerable<string> caselines = File.ReadAllLines(openFileDialog1.FileName).Reverse();

                                    foreach (string caseline in caselines)
                                    {
                                        var co = caseline.Split(',');

                                        double co0 = Convert.ToDouble(co[0]);
                                        double co1 = Convert.ToDouble(co[1]);
                                        double co2 = Convert.ToDouble(co[2]);
                                        double co3 = Convert.ToDouble(co[3]);
                                        double co4 = Convert.ToDouble(co[4]);
                                        double co5 = Convert.ToDouble(co[5]);
                                        string co6 = co[6];

                                        if (co6 == minDateTime || (Convert.ToDateTime(co[6]) >= Convert.ToDateTime(minDateTime) && Convert.ToDateTime(co[6]) <= Convert.ToDateTime(maxDateTime)))
                                        {
                                            lists.Add(co0.ToString());
                                            lists.Add(co1.ToString());
                                            lists.Add(co2.ToString());
                                            lists.Add(co3.ToString());
                                            lists.Add(co4.ToString());
                                            lists.Add(co5.ToString());
                                            lists.Add(co[6]);
                                        }
                                        else if (Convert.ToDateTime(co6) > Convert.ToDateTime(maxDateTime))
                                        {
                                            break;
                                        }
                                    }

                                    searchProgressBar.Maximum = lists.Count() / 7;
                                    searchDataNumber.Text = (lists.Count() / 7).ToString();

                                    int a = 0;

                                    foreach (string caseline2 in caselines)
                                    {
                                        var cols = caseline2.Split(',');

                                        double cols0 = Convert.ToDouble(cols[0]);
                                        double cols1 = Convert.ToDouble(cols[1]);
                                        double cols2 = Convert.ToDouble(cols[2]);
                                        double cols3 = Convert.ToDouble(cols[3]);
                                        double cols4 = Convert.ToDouble(cols[4]);
                                        double cols5 = Convert.ToDouble(cols[5]);
                                        string cols6 = cols[6];

                                        if (cols6 == minDateTime || (Convert.ToDateTime(cols[6]) >= Convert.ToDateTime(minDateTime) && Convert.ToDateTime(cols[6]) <= Convert.ToDateTime(maxDateTime)))
                                        {
                                            dataGridView2.Rows.Add();

                                            dataGridView2.Rows[a].Cells[0].Value = cols0;
                                            dataGridView2.Rows[a].Cells[1].Value = cols1;
                                            dataGridView2.Rows[a].Cells[2].Value = cols2;
                                            dataGridView2.Rows[a].Cells[3].Value = cols3;
                                            dataGridView2.Rows[a].Cells[4].Value = cols4;
                                            dataGridView2.Rows[a].Cells[5].Value = cols5;
                                            dataGridView2.Rows[a].Cells[6].Value = cols[6];

                                            searchProgressBar.PerformStep();
                                            Application.DoEvents();

                                            a++;
                                        }

진행하다 보면 속도가 갑자기 느려지는 데 이 때 dataGridView2 를 한 번 키고 꺼주면 속도가 다시 올라간 후 그 속도로 유지됩니다.
원인이 무엇인가요 ??
속도가 느려지는 원인은 UI 에 표시하기 때문일 것으로 추측되지만 표를 끄고 있기 때문에 이 추측은 신빙성이 낮아 보여서 도무지 알 길이 없네요..




donaricano-btn



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


비밀번호

댓글 쓴 사람
 



2017-08-30 04시18분
표를 끄고 있다는 것이 무슨 의미죠? dataGridView2.Rows.Add()만 있고 Remove는 없다면 rows가 너무 많아져서 그런 거 아닐까요? 이런 식의 코드 조각 말고 재현 가능한 최소한의 예제 프로젝트같은 거는 만들 수 없나요?
정성태
2017-08-30 08시12분
[kmi] 음.. 평상시엔 GridView2 를 Visible 하지 않고 있다가 검색 후 GridView2 를 Visible = true 하고 시간이 조금 지나면 속도가 느려지는 데 이 때 혹은 true로 바꾼 후 다시 바로 false 로 바꾸면 속도가 다시 빨라지는 현상입니다. Remove 는 검색 한 값을 모두 표시하고 있어야 하기에 사용할 수 없고 rows 가 1만개 아래라면 별로 체감이 안나지만 40만개 이상 넘어가면 체감이 좀 많이 오더라구요. 예제 프로젝트는 올려드린다 해도 만드는 데 시간이 조금 걸려서 바로는 올려드리기 힘들 것 같습니다 ㅜ
[손님]
2017-09-16 07시07분
[순디] 어떤 확장자의 파일인지 모르겟으나 6번째 데이터가 생성일자로 파악되며, 그리드의 데이터가 실시간 바인딩이 아니라면 위의 방법말고 데이터테이블 객체에 담이서 바인딩하시는게 어떤지요? 그리고 파일 데이터 처리? 하려고 왜 40만개의 데이터를 리스트에 담고 데이터그리드에 다시 바인딩다시하셔야만 되는 이유를 모르겟네요 반복문 하나로 가능할텐데 말이죠
[손님]

1  2  3  4  5  6  7  8  9  10  11  12  13  14  [15]  ...
NoWriterDateCnt.TitleFile(s)
5071엔벌잉10/23/20182788C#윈도우폼 질문입니다!! [2]
5070진우10/17/20182320Visual Studio 서비스팩과 업데이트 차이 문의 [2]
5069감자10/12/20182659빌드 구성을 재설정하는 방법이 있을까요? [1]파일 다운로드1
5068누오10/10/20182332ASP Core 2.0 에서 dll안에 있는 뷰 읽어들이는 방법? [1]
5067김정민10/5/20182312다른 윈도우가 깨지는 현상을 막을 수 있을까요 [3]
5066로니브10/4/20182666ASP.NET MVC에서 View 파일 숨기는법? 보안처리 하는법? 관련 질문.. [1]
5065키모10/1/20182314문자 질문입니다. [3]
5064로니브10/1/20182776클래스 라이브러리에서 .cshtml파일을 추가하는 방법은 없나요? [3]
5063진우9/28/20182367ADO.net 과 Entity Framework 차이 문의 [2]
5062테스트9/27/20182074C# import file 의 구조체 배열 선언 및 호출에 대해 문의. [3]
5061안녕하세요9/13/20182575c# 프로그래밍 관련 문의 [1]
5060임민재9/8/20182433c# install 파일 생성 시 문제가 발생하였습니다 [1]파일 다운로드1
50599/7/20182174Winform TextBox 포커스 유지하는 방법 질문 [파일첨부] [1]파일 다운로드1
50589/5/20183722Winform TextBox 포커스 유지하는 방법 질문 [3]
5056박종윤8/30/20183595c# dll을 C++에서 사용 시 event 호출 [4]파일 다운로드1
5055초보자8/29/20182860asp.net 에서 다른 서버의 iis를 stop하는 batch file을 실행시키는데 동작하지 않습니다. [5]
5054사도신8/29/20182441[wpf] textbox insert overite 모드시에 [4]파일 다운로드1
5053엿장수8/26/20182263directshow filter 에서의 IMediaSample 의 시간에대한질문입니다 [1]
5052오명현8/26/20182769Tcp소켓 실습 Exeption 도와주세요! [4]파일 다운로드1
5049오명현8/23/20182324책 477페이지 내용 중 이해가 안가는 부분이 있어 질문드립니다. [1]
5048오명현8/23/20182179포트 관련 질문 하나더 있습니다. [1]
5047오명현8/22/20182810포트가 없을 경우를 가정한 내용에 대해 질문이 있습니다. 책468p. [1]
5046엿장수8/22/20182507다이렉트쇼 필터 추가하는데 [2]
5045임도진8/22/20183160c# opencv dll파일 로드 질문 [3]파일 다운로드1
5044엿장수8/20/20182488graphedit 에 등록되어있는 필터를 가져와서 사용하는방법을 알고싶습니다 [2]
5043horizon8/20/20182368Expression에 대한 책의 예제 관련하여 질문드립니다. [1]
1  2  3  4  5  6  7  8  9  10  11  12  13  14  [15]  ...