1. for구문은 고치는게 맞습니다.
copy-paste하면서 저도 모르게 바뀌어 벼렸네요
2. ++ 연산자는 계산을 수행후에 값을 증가시키죠
//다음 구문은
data[serial_number++] = serial_data[i] ;
//아래와 같이 풀어쓸수 있습니다.
data[serial_number]=serial_data[i] ;
serial_number++;
3. 에러는?
저도 직접 serialport를 이용하여 테스트 해보지 않아서 정확히는 잘 모르겠지만
저도 실수한곳이 있네요
// 문제의 구문은...
static char data[500],serial_number = 0;
// 위 구문에 보면 serial_number 가 char 형으로 선언되어잇습니다.
static char serial_number = 0;
// char형이면 범위가 -128 에서 127 까지죠
// 즉 128넘어가면 access-voilation이 날수 밖에 없네요
static char data[500];
static int serial_number = 0;
//이렇게 int형으로 선언하심이좋을듯...
//
그럼..
번외편 님이 쓰신 글 :
: 코드를 수정해서 바로잡아주시면 저야 좋져 ㅎㅎ
: 답변 감사드립니다.
: 헌데
: for(int i=0;i;i++) <-- 이부분은 for(int i=0;Count;i++) 가 맞는거죠?
:
: data[serial_number++] = serial_data[i] ; <- 이렇게도 증가가 되는건가요?
: 실행시켜보니깐 Violation 에러가 나네요..
:
:
:
:
:
:
: 장성호 님이 쓰신 글 :
: : 코드를 보니 목적이?
: :
: : SerialPort로 들어오는 Data를 0x0D 가 들어오면 짤라서 Memo에 넣어 주는군요
: : 그런데 시작부분이 0x1b 즉 ESC 값이 들어오면 그 LINE은 넘어가구요
: :
: : 맞습니까?
: :
: : 님의 코드를 좀 수정해 보았습니다.
: : 함부로 수정해서 죄송하구요 도움이 되길 바랍니다.
: :
: :
: :
| |
: :
: : void __fastcall TForm1::Comm1RxChar(TObject *Sender, DWORD Count)
: : {
: : // char str[500]; 필요없음
: : //unsigned char buffer=0; 필요없음
: : // DWORD i,j; 필요없음 for 구문의 증감변수는 for문에 선언
: : //char Buff[100]; 필요없음
: : //int k; 필요없음
: :
: : static char data[500],serial_number = 0;
: : char serial_data[500];
: :
: : String Str_Data;//new를 하지 말고 그냥 선언
: :
: : Comm1->Read(serial_data,Count);
: :
: : for(int i=0;i;i++)
: : {
: : //넣으면서 serial_number 증가 시킴
: : data[serial_number++] = serial_data[i] ;
: :
: : //serial_number를 증가시켰으므로 serial_data로 비교
: : if( serial_data[i] == 0x0d )
: : {
: : //data[serial_number] = serial_data[i] ; 필요없음
: :
: : //esc , esc 가 아니면
: : if( (data[0] != 0x1b) && (data[1] != 0x1b) )
: : {
: : //이렇게
: : data[serial_number]=0;
: : Str_Data=data;
: : Memo1->Lines->Add(Str_Data ) ;
: :
: : //또는 이렇게
: : //이경우는 Str_Data 라는 string변수가 필요없겠네요
: : data[serial_number]=0;
: : Memo1->Lines->Add(data ) ;
: :
: : }
: : serial_number = 0;
: : memset(data,0,500); //사실 이부분도 없어도 됨
: : }
: : }
: : }
: : | |
: :
: :
: :
: : 그럼..
: :
: :
: : 번외편 님이 쓰신 글 :
: : : 일단 아까 그 문제는 해결이 되었네요..
: : : 너무 어려운길을 선택했었네요 memicmp;;
: : : strstr로 해결했습니다.
: : :
: : : 그런데 데이터가 한꺼번에 많이 들어올때 시빌더가 다운이 되는데
: : : 이게 왜이럴까요? 버퍼사이즈를 늘려줘도 버퍼를 초기화를 해줘도 다운이 되는데
: : : 처리속도가 느려서 그런걸까요? baudrate는 19200(터미널창으로 할때는 다운되지 않습니다)
: : : 구여 도중에 받는 도중에 if문이 여러개 있어서 처리하느라고 다운되는줄 알고
: : : if문을 다 빼도 시빌더가 멈추네요.
: : :
: : :
: : : memo 창도 따로 초기화를 해줘야 하나요?
: : :
: : : 소스 함께 올립니다. 문자열 [50]개가 쌓이기 전에 0x0d는 꼭 들어옵니다.
: : :
: : : void __fastcall TForm1::Comm1RxChar(TObject *Sender, DWORD Count)
: : : {
: : : char str[500];
: : : unsigned char buffer=0;
: : : DWORD i,j;
: : : char Buff[100];
: : : int k;
: : : static char data[500],serial_number = 0;
: : : char serial_data[500];
: : :
: : : String *Str_Data =new String;
: : : Comm1->Read(serial_data,Count);
: : :
: : : for(i=0;i<Count;i++)
: : : {
: : : data[serial_number] = serial_data[i] ;
: : :
: : : if( data[serial_number] == 0x0d )
: : : {
: : : data[serial_number] = serial_data[i] ;
: : :
: : : if( (data[0] != 0x1b) && (data[1] != 0x1b) )
: : : {
: : : *Str_Data = (char)data[0];
: : : for(j=1;j<serial_number ;j++)
: : : {
: : : *Str_Data = *Str_Data + (char)(data[j]);
: : : }
: : :
: : : Memo1->Lines->Add(*Str_Data ) ;
: : : }
: : : serial_number = 0;
: : : memset(data,0,500);
: : : }
: : : else
: : : {
: : : serial_number++ ;
: : : }
: : : }