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

시리얼 통신으로 수신된 패킷을 각 항목을 나눠서 그리드뷰에 뿌려주는 프로그램을 만들고 있습니다.
100개 넘게 뿌려지는걸 굳이 확인을 안했는데
오늘 최종 보고 전 확인해보니 150개를 넘어가는 지점부터 뿌려주는 속도가 확 느려집니다
Interval은 1000ms이며,
인터벌을 주기 위해서 Thread.Sleep()을 선언했으며, Thread 동작을 진행 된 후 뿌려줍니다.

진행 순서는
1. SerialPort.cs에서 송신 패킷, 수신 패킷을 구하며, 수신 패킷을 구한 뒤 아래와 같은 이벤트를 발생시킵니다.
DataReceive.Invoke(this, new DataReceiveArgs(i_StartAddress, b_SendBytes, b_resultArray));

2. Serve.cs에선 각 패킷들을 분류한 후, 조건에 맞춰 이벤트를 아래와 같이 발생 시킵니다.
  ReadReceived?.Invoke(this, readDataReceivedEvent);

            if (this.RunningMode == ModbusRunningMode.Normal)
            {
                if (this.stopRead == true)
                {
                    this.serialportsettings.Close();
                    this.IsRunning = false;
                    return;
                }
                //Thread.Sleep(this.Interval);
                this.serialportsettings.WritePkt(this.SlaveAddress, this.DataAddress, this.DataLength);
            }

제 추측으론 1번 순서에서 점차 느려지는거 같은데 혹시 어디를 손 봐야할까요??
도움을 부탁드립니다.
적다보니 질문이 애매한 부분이 있을 수 있을꺼라 생각이 됩니다. 지적해주시면 다시 정정하겠습니다.








[최초 등록일: ]
[최종 수정일: 9/4/2020]


비밀번호

댓글 작성자
 



2020-09-04 02시51분
구간마다 Stopwatch를 쓰면 어디서 느려지는지 쉽게 알 수 있을 것 같은데요. 혹은, 문제 재현을 위해 SerialPort를 물리적으로 통신하지 말고 가짜 데이터로 Datareceive.Invoke를 호출하는 식으로 처리해 보는 것도 좋을 듯합니다.
정성태
2020-09-07 02시01분
[정씨] 그리드뷰에 뿌려줄 때 점차 처리 속도가 느려지는것을 확인했습니다.
지금은 그리드뷰에 뿌리기 위해서
아래처럼 항목 5개의 값을 뿌리기 위해선
[항목1][항목2][항목3][항목4][항목5]
[결과1][결과2][결과3][결과4][결과5]
순차 적으로 결과 1 > 결과 2 > ...결과 5
이렇게 동작하기 때문에 느린게 아닐까? 생각이 듭니다 그래서 데이터 바인딩을 할려고 하는데
바인딩을하니 로우가 계속 추가되지 않습니다...
코드는 아래와 같습니다.

   DataTable table = new DataTable();
            DataRow dataRow = table.NewRow();
            DataSet dataSet = new DataSet();

            foreach (ReadDataItem item in readDataItems)
            {
                DataColumn column = new DataColumn(item.Address.ToString(), item.DataType);
                table.Columns.Add(column);

            }

            table.Rows.Add();
            foreach (ReadDataItem item in readDataItems)
            {
                table.Rows[table.Rows.Count - 1][item.Address.ToString()] = item.Value;
            }

            dataGridView1.DataSource = null;

            foreach (ReadDataItem item in readDataItems)
            {
                dataGridView1.Columns.Add(item.Address.ToString(), item.Desc);
                dataGridView1.Columns[item.Address.ToString()].DataPropertyName = item.Address.ToString();
            }

            dataGridView1.DataSource = table;


[guest]
2020-09-07 03시28분
가짜 데이터로 해당 현상을 재현할 수 있는 최소한의 예제 코드를 올려주세요.
정성태

... 31  32  33  34  35  36  [37]  38  39  40  41  42  43  44  45  ...
NoWriterDateCnt.TitleFile(s)
4936무개1/3/20188796책 내용 인용하는 것에 관한 질문이있습니다. [1]파일 다운로드1
4935몬난아12/28/201711546IIS 및 ASP.NET 이 서버에서의 동작방식? [2]
4934Ques...12/26/201721926C# 해상도에 따른 자동 사이즈 조절방법이 궁금합니다. [3]
4933Kay12/15/20179227C# VS 버전 에러 질문 드립니다. [1]파일 다운로드1
4932정환나라12/13/20179126vs2013에서 빌드한 com 컨트롤 객체를 닷넷 2.0에서 사용하려 합니다 [4]
4931Arvid12/12/201710163Visual Studio 2012 c# using문 참조 에러 [5]파일 다운로드1
4929김성대12/8/20178653app.config에 관한질문입니다. [1]
4928김성대12/7/20179316SQL Server 설치에러에 대한 질문입니다. [1]파일 다운로드1
4926heyh...12/6/20178550[삭제] ContextSwitchDeadlock????
4925ho12/5/20179090[삭제] WebBrowser로 드롭박스 로그인 페이지 탐색 시 발생한 문제에 대해 질문 올립니다.파일 다운로드2
4924몽중언12/3/20179537C# 디버깅 모드에서만 DB Insert가 되는 현상 질의 [6]
4923고요한11/23/20179650파일 확장자에 연결된 프로그램을 등록하는 방법에 대한 질문입니다. [2]
4922박성훈11/23/201710612시작하세요! C# 7.1 학습 방법 [3]
4921초보개발자11/20/20177851[삭제] 폼 사이즈 질문드립니다.
4920Ques...11/19/20178968IEnumerable 의 "지연된 평가" 에 관하여 질문드립니다. [2]파일 다운로드1
4919mskim11/16/20179263Split()을 이용하여 문자 구분 시 구분문자도 같이 저장하는 방법이 있나요? [2]
4917ho11/16/20179894WPF XAML 트리거 관련해 문의 드립니다. [3]
4918ho11/16/201710192    답변글 [답변]: 예제 프로젝트 첨부합니다. [4]파일 다운로드2
4916필승11/11/20179855기본 웹 브라우저 체크는 어떻게 해야 하나요? [2]
4915필승11/10/20178921WebBrowser 컨트롤 소리 출력 문의 드립니다. [2]
4914Ques...11/10/20179608c# 버튼 이벤트에 관하여 질문드립니다. [2]
4913Arvid11/8/201712043Log4Net 라이브러리를 이용하여 특정 기간이 지났을 때 자동 로그 삭제 기능 구현 질문 드립니다! [2]
4912조범희11/8/201711697C# FTP 다운로드중 에러 발생.. [2]파일 다운로드1
4911필승11/6/201710136WebBrowser 컨트롤 사용법에 대해 궁금합니다. [2]
4910진우11/6/20179715람다 초보 질문 드립니다. [2]
4909필승11/5/201710637TextBox에 관해 질문 드립니다. [5]
... 31  32  33  34  35  36  [37]  38  39  40  41  42  43  44  45  ...