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

... 61  62  63  64  65  66  67  [68]  69  70  71  72  73  74  75  ...
NoWriterDateCnt.TitleFile(s)
888김재영7/5/201014372TFS에 반드시! SQL Report랑 SharePoint(or WSS)가 붙어야 합니까? [2]
887임동찬7/2/201015698WCF sendTimeout에 관하여... [1]
886김재영6/16/201015701스레드 선언시 (Parameterized/)ThreadStart에 정의되는 메소드의 위치에 질문이 있습니다. [3]
885장근배6/13/201023107Win32Exception 창 핸들 에러 [1]
883채동민6/10/201015294비동기 DB 쿼리관련 질문
884정성태6/10/201016747    답변글 [답변]: 비동기 DB 쿼리관련 질문
881최준영5/24/201016523load되지않은 아이템 load하는 방법? [1]
880임상일5/10/201018616VS2010 TestManager를 통한 UI Test 관련 질문입니다. [2]파일 다운로드1
879정용훈5/3/201019857wcf 인증 문제 [2]
878채동민4/20/201019059WCF에서 maxItemsInObjectGraph 오류 관련 질문드립니다. [2]
872날쌘돌이4/8/201021755Windows7 에서 IIS에서 폼인증 으로 디버깅.. [1]파일 다운로드1
871영초4/7/201017117실버라이트로 스캐너 구동 프로그램이 가능할까요? [1]
869김재영4/6/201016000이미 실행된 어셈블리 컨트롤 권한을 다른 어셈블리에서 가져올 수 있습니까? [2]
868Lime3/5/201019603WCF 에서의 DataTable 사용 [2]
867Dani...2/18/201019733Question - HTTP 401.3 on DELETE, PUT verbs [6]파일 다운로드1
865박근대2/16/201016221WCF 오류 문의. [1]
863날쌘돌이1/31/201018564ActiveX Cab에서 닷넷 dll 등록 [1]
862장근배1/28/201016358AppPolId를 알 수 있는 방법이 있는지요? [1]
864장근배2/1/201016017    답변글 [답변]: AppPolId를 알 수 있는 방법이 있는지요?
858생초보1/26/201016366안녕하세요.. 파일 생성 처리 문제로 .... [2]
857꼭지1/22/201022106How to support Basic + Windows authentication mode in WCF(RESTful service) [4]파일 다운로드2
856질의자1/13/201020068vcredist_x86 배포 관련 여쭙습니다. [1]
855임동찬1/13/201018166이벤트 핸들러와 쓰레드의 관계 2 [4]파일 다운로드2
854임동찬1/12/201018449이벤트 핸들러와 쓰레드의 관계 [1]
853장근배1/12/201018048압축 프로그램,, [1]
852임동찬1/6/201015440base.OnStart(agrs) [1]
... 61  62  63  64  65  66  67  [68]  69  70  71  72  73  74  75  ...