TCP 프로 토 콜 기반 병렬 서버 프로그램
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
// ,
void *thr_fn ( void *arg )
{
int size, j;
char recv_buf[1024];
int *parg = ( int * ) arg;
int new_fd = *parg;
while ( ( size = read ( new_fd, recv_buf, sizeof ( recv_buf ) ) ) > 0 ) {
if ( recv_buf[0] == '@' ) {
break;
}
printf ( "Message from client(%d): %s
", size, recv_buf );
for ( j = 0; j < size; ++j )
recv_buf[j] = toupper(recv_buf[j]);
write(new_fd,recv_buf,size);
}
close(new_fd);
return 0;
}
int main(int argc, char *argv[]){
socklen_t clt_addr_len;
int listen_fd;
int com_fd;
int ret;
int i;
static char recv_buf[1024];
int len;
int port;
pthread_t tid;
struct sockaddr_in clt_addr;
struct sockaddr_in srv_addr;
// ,
if(argc != 2){
printf("Usage:%s port
",argv[0]);
return -1;
}
//
port = atoi(argv[1]);
//
listen_fd = socket(PF_INET,SOCK_STREAM,0);
if(listen_fd < 0){
perror("cannot create listening socket");
return -1;
}
//
memset(&srv_addr,0,sizeof(srv_addr));
srv_addr.sin_family = AF_INET;
srv_addr.sin_addr.s_addr = htonl(INADDR_ANY);
srv_addr.sin_port = htons(port);
//
ret = bind(listen_fd,(struct sockaddr *)&srv_addr,sizeof(srv_addr));
if(ret == -1){
perror("cannot bind server socket");
close(listen_fd);
return -1;
}
//
ret = listen(listen_fd,5);
if(ret == -1){
perror("cannot listen the client connect request");
close(listen_fd);
return -1;
}
/*
, ,
read
"@" ,
*/
while(1){
len = sizeof(clt_addr);
com_fd = accept(listen_fd,(struct sockaddr *)&clt_addr,&len);
if(com_fd < 0){
if(errno == EINTR)
continue;
else{
perror("cannot accept client connect request");
close(listen_fd);
return -1;
}
}
printf("com_fd = %d
",com_fd); //
if((pthread_create(&tid,NULL,thr_fn,&com_fd)) == -1){
perror("pthread_create error");
close(listen_fd);
close(com_fd);
return -1;
}
}
return 0;
}
클 라 이언 트:
#include
#include
#include
#include
#include
#include
int main(int argc, char**argv){
int connect_fd;
int ret;
char snd_buf[1024];
int i;
int port;
int len;
static struct sockaddr_in srv_addr;
//
if(argc != 3){
printf("Usage: %s server_ip_address port
",argv[0]);
return -1;
}
//
port = atoi(argv[2]);
//
connect_fd = socket(PF_INET,SOCK_STREAM,0);
if(connect_fd < 0)
{
perror("cannot create communication socket");
return 1;
}
//
memset(&srv_addr,0,sizeof(srv_addr));
srv_addr.sin_family = AF_INET;
srv_addr.sin_addr.s_addr = inet_addr(argv[1]);
srv_addr.sin_port = htons(port);
//
ret = connect(connect_fd,(struct sockaddr *)&srv_addr,sizeof(srv_addr));
if(ret == -1){
perror("cannot connect to the server");
close(connect_fd);
return -1;
}
memset(snd_buf,0,1024);
/*
, ,
read
"@" ,
*/
while(1){
write(STDOUT_FILENO,"input message:", 14);
len = read(STDIN_FILENO,snd_buf,1024);
if(len > 0)
write(connect_fd,snd_buf,len);
len = read(connect_fd,snd_buf,len);
if(len > 0)
printf("Message form server: %s
",snd_buf);
if(snd_buf[0] == '@')
break;
}
close(connect_fd);
return 0;
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
바이너리 파일cat 또는tail, 터미널 디코딩 시 처리 방법cat으로 바이너리 파일을 보려고 할 때 코드가 엉망이 되어 식은땀이 났다. 웹에서 스크롤된 정보의 처리 방법과alias의 설정을 요약합니다. reset 명령을 사용하여 터미널을 재설정합니다.이렇게 하면 고치지 못하...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.