recv(2)

#include <sys/types.h>
#include <sys/socket.h>

ssize_t recv(int sockfd, void *buf, size_t len, int flags);

connect(2) 또는 accept(2) 등으로 연결된 socket으로부터 데이터를 수신합니다. 일반적인 데이터를 읽을 때에는 read(2) 함수를 사용할 수 있습니다. read(sockfd, buf, len) == recv(sockfd, buf, len, 0)

 

 

파라미터

sockfd
    - connect(2), accept(2)로 연결된 socket descriptor
buf
    - data를 수신하여 저장할 buffer
len
    - 읽을 데이터 크기
flags
    - 읽을 데이터 유형 또는 읽는 방법에 대한 option

 MSG_OOB : out of band(긴급데이터) 데이터를 읽습니다. 
           주로 X.25에서 접속이 끊겼을 때에 전송되는 데이터
 MSG_PEEK : receive queue의 데이터를 queue에서 제거하지 않고 확인하기 위한 목적으로 설정함
 MSG_WAITALL : 읽으려는 데이터가 buffer에 찰 때까지 대기함

 flags의 값이 0이면 일반 데이터를 수신하며, read(sockfd, buf, len)을 호출한 것과 같습니다.

 

RETURN

0 이상
    - 정상적으로 데이터를 수신하였으며, 실제로 수신한 데이터의 길이를 return합니다.

-1
    - 오류가 발생하였으며, 상세한 오류 내용은 errno에 저장됩니다.

 EAGAIN or EWOULDBLOCK : time out이 발생하였거나 socket에 non-blocking이 설정된 경우
 EBADF    : sockfd가 유효하지 않는 descriptor
 ECONNREFUSED : network상에서 접속 거부된 경우
 EFAULT   : 읽을 데이터를 저장할 buf가 유효하지 않은 메모리인 경우
 EINTR    : signal이 발생하여 interrupted 된 경우, 다시 읽기 필요
 EINVAL   : 파라미터의 값이 유효하지 않은 경우
 ENOMEM   : 데이터 수신을 위한 메모리 할당이 되지 않은 경우 (recvmsg(2)호출시)
 ENOTCONN : connect(2), accept(2)가 호출되지 않은 상태인 경우
 ENOTSOCK : sockfd가 socket descriptor가 아닌 일반 파일인 경우

 


활용 예제

 

#include <errno.h>
#include <string.h>
#include <sys/types.h>
#include <sys/socket.h>

......

char    buffer[2048];
int     recv_len;

......

while( (recv_len = recv(sockfd, buffer, 256, 0)) == -1) {
    if(errno == EINTR) { // signal이 발생하여 읽지 못한 경우
        continue;
    } else {
        fprintf(stderr, "Recv Error: %s\n", strerror(errno));
        return -1;
    }
}

......

 


see also : Socket 통신과 Socket 응용

 

 

 

 

블로그 이미지

자연&사람

행복한 개발자 programmer since 1995.

댓글을 달아 주세요