recv WAITALL 옵션에 대한 문제...
글쓴이: nakorori / 작성시간: 목, 2007/10/25 - 4:55오후
기본적인 흐름은
클라이언트가 서버에 받고싶은 데이터 주소와 데이터 길이를 전달해주면
서버는 그 데이터 주소에서 데이터 길이를 클라이언트에게 전송해 줍니다.
MSG_WAITALL 옵션을 쓰지 않는것이 좋은것 같아.
처음에 recvAll 이라는 함수를 만들어 사용했습니다.
int recvAll(int sock, char* data, int size){
int n = 0;
for(;;){
if( (n=recv(sock,data,size,MSG_NOSIGNAL))<size){
if(n<0){
perror("recv failed ");
return -1;
}else if(n == 0){
break;
}
data += n;
size -= n;
}
if(size == n)
break;
}
}1번 방법
if( recvAll(sock,(char*)data,len) < 0){
fprintf(stderr,"recv error\n");
shutdown(sock,SHUT_RDWR);
close(sock);
}2번 방법
if( recv(sock,(char*)data,len,MSG_WAITALL) < 0){
perror("recv error\n");
shutdown(sock,SHUT_RDWR);
close(sock);
}이후 재접속
1번 방법을 사용할 경우에 가끔씩 잘못된 데이터를 가져옵니다.
같이 일하는 동생은 recv 버퍼에 올바른 데이터가 아닌경우에도 recv가 읽어오는 경우가 있다고 하던데...
도데체 return 값을 믿을수가 없어지니...;;
2번방법을 사용할 경우에는 잘못된 데이터를 받아온적이 없습니다.
제가 구현한 recvAll이 잘못된 걸까요??
Forums:


검색의 생활화
이런 질문하기전에 검색부터좀 하시죠?
쯧쯧
Re: 로직상에 허점...
방식 자체는 맞습니다만, 로직상에 허점이 하나 있네요.
recv() 함수의 첫 실행 결과가 받고자 하는 데이터의 절반만을 받아왔을때,
size -= n; 라인의 결과로 인해 size == n 이 되고
바로 아래에 있는 if 문에 의해서 함수가 종료되는 허점이 있네요.
댓글 달기