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분
가짜 데이터로 해당 현상을 재현할 수 있는 최소한의 예제 코드를 올려주세요.
정성태

... 46  47  48  49  50  51  52  53  54  55  56  [57]  58  59  60  ...
NoWriterDateCnt.TitleFile(s)
1241(non...3/22/201421118(글쓴이의 요청으로 삭제합니다.) [4]
1240이석주3/21/201423789인터넷 익스플로러가 hang이 걸리는 현상 문의 [1]파일 다운로드1
1238(non...3/13/201417708(글쓴이의 요청으로 삭제합니다.) [2]
1237(non...3/11/201417747(글쓴이의 요청으로 삭제합니다.) [2]
1236(non...3/11/201418602(글쓴이의 요청으로 삭제합니다.) [2]
1235(non...3/10/201417685(글쓴이의 요청으로 삭제합니다.) [2]
1234(non...3/10/201420880(글쓴이의 요청으로 삭제합니다.) [3]
1233(non...3/9/201418554(글쓴이의 요청으로 삭제합니다.) [4]
1232(non...3/8/201417450(글쓴이의 요청으로 삭제합니다.) [2]
1231(non...3/7/201418743(글쓴이의 요청으로 삭제합니다.) [9]
1230POCO3/7/201419094쓰레드 안에서 DependencyProperty get, set시 또 다른 스레드 오류.. [1]
1229(non...3/6/201419756(글쓴이의 요청으로 삭제합니다.) [11]
1228POCO3/6/201417805안녕하세요. 질문이 있습니다. [1]
1226김형진3/4/201427964안녕하세요 windows azure에 관해 질문했던 사람입니다. [2]
1224(non...3/3/201423279(글쓴이의 요청으로 삭제합니다.) [11]
1223sadf...3/3/201417816아래 질문에 답변 감사드립니다. 한가지 더 궁금한점이 있어 질문드립니다. [1]
1222(non...3/2/201418262(글쓴이의 요청으로 삭제합니다.) [4]
1221(non...3/1/201418692(글쓴이의 요청으로 삭제합니다.) [2]
1220Until2/28/201416998질문드립니다. [1]
1219이성환2/28/201416468string.Join()과 Enumerable.Aggregate()의 차이가 궁금합니다. [2]파일 다운로드1
1218김형진2/25/201418278안녕하세요. window azure에 대해서 질문이 있어서 문의 드립니다 [4]
1217(non...2/23/201418878(글쓴이의 요청으로 삭제합니다.) [1]
1215아리수2/20/201422294C# 공부하면서 WPF에 대한 질문. [2]
1214조광훈2/20/201420300IIS8 응용프로그램 풀 관련 질문 드립니다. [2]파일 다운로드1
1213김태훈2/17/201417499가상화 프로그램 질문입니다. [1]파일 다운로드1
1212조광훈2/13/201416269ISAPI 필터에서 커스텀 헤더 정보 추가 [1]파일 다운로드1
... 46  47  48  49  50  51  52  53  54  55  56  [57]  58  59  60  ...