컴파일 에러인데...어디가 잘못된건지 모르겠네요
글쓴이: ch0nn0m / 작성시간: 일, 2009/08/16 - 2:50오후
책에 나온 채팅프로그램을 따라 만들어본건데요...컴파일이 안되네요..
어디가 잘못된건지...?
에러내용은 소스코드밑에...
서버..
#include<stdio.h> #include<stdlib.h> #include<string.h> #include<unistd.h> #include<arpa/inet.h> #include<sys/types.h> #include<sys/socket.h> #include<pthread.h> #define PORT 8888 int clnt_number=0; int clnt_socks[10]; pthread_mutex_t mutx; void *clnt_connection(void *arg) { int clnt_sock=(int)arg; int str_len=0; char message[512]; int i; while((str_len=read(clnt_sock,message,sizeof(message))) != 0) send_message(message,str_len); pthread_mutex_lock(&mutx); for(i=0; i<clnt_number; i++) { if(clnt_sock==clnt_socks[i]) { for( ; i<clnt_number-1; i++) clnt_socks[i]=clnt_socks[i+1]; break; } } clnt_number--; pthread_mutex_unlock(&mutx); close(clnt_sock); return 0; } void send_message(char *message, int len) { int i; pthread_mutex_lock(&mutx); for(i=0; i<clnt_number; i++) write(clnt_socks[i], message, len); pthread_mutex_unlock(&mutx); } int main(int argc, char **argv) { int serv_sock; int clnt_sock; struct sockaddr_in serv_addr; struct sockaddr_in clnt_addr; int clnt_size; pthread_t thread; if(pthread_mutex_init(&mutx, NULL)) { printf("mutex init error\n"); exit(1); } serv_sock=socket(PF_INET, SOCK_STREAM, 0); if(serv_sock==-1) { printf("socket() error\n"); exit(1); } memset(&serv_addr,0,sizeof(serv_addr)); serv_addr.sin_family=AF_INET; serv_addr.sin_addr.s_addr=htonl(INADDR_ANY); serv_addr.sin_port=htons(PORT); if(bind(serv_sock,(struct sockaddr*) &serv_addr, sizeof(serv_addr))==-1) { printf("bind() error\n"); exit(1); } if(listen(serv_sock, 5)==-1) { printf("listen() error\n"); exit(1); } while(1){ clnt_size=sizeof(clnt_addr); clnt_sock=accept(serv_sock,(struct sockaddr*) &clnt_addr,&clnt_size); if(clnt_sock==-1) { printf("accept() error\n"); exit(1); } pthread_mutex_lock(&mutx); clnt_socks[clnt_number++]=clnt_sock; pthread_mutex_unlock(&mutx); pthread_create(&thread, NULL, clnt_connection, (void*)clnt_sock); printf("새로운 연결 클라이언트 ip: %s\n",inet_ntoa(clnt_addr.sin_addr)); } return 0; }
컴파일 했더니...
cfs.c:70: warning: type mismatch with previous implicit declaration
cfs.c:53: warning: previous implicit declaration of `send_message'
cfs.c:70: warning: `send_message' was previously implicitly declared to return `int'이런에러가 나오네요...
클라이언트..
#include<stdio.h> #include<stdlib.h> #include<string.h> #include<unistd.h> #include<arpa/inet.h> #include<sys/types.h> #include<sys/socket.h> #include<pthread.h> #define PORT 8888 char name[20]; char message[512]; void *send_message(void *arg) { int sock=(int)arg; char name_message[532]; while(1) { fgets(message, 512, stdin); if(!strcmp(message,"q\n")) { close(sock); exit(0); } sprintf(name_message," %s %s",name,message); write(sock, name_message, strlen(name_message)); } } void *recv_message(void *arg) { int sock=(int)sock; char name_message[532]; int str_len; while(1) { str_len=read(sock, name_message, 531); name_message[str_len]='\0'; fputs(name_message, stdout); } } int main(int argc,char **argv) { int sock; int str_len, recv_len, recv_num; struct sockaddr_in serv_addr; pthread_t send_thread, recv_thread; void *thread_result; if(argc !=3 ){ printf("Usage : %s <IP> <port>\n", argv[0]); exit(1); } sprintf(name, "[%s]", argv[3]); sock=socket(PF_INET,SOCK_STREAM,0); if(sock == -1) error_handling("socket() error"); memset(&serv_addr,0,sizeof(serv_addr)); serv_addr.sin_family=AF_INET; serv_addr.sin_addr.s_addr=inet_addr(argv[1]); serv_addr.sin_port=htons(PORT); if(connect(sock,(struct sockaddr*)&serv_addr,sizeof(serv_addr))==-1) { printf("connect() error\n"); exit(1); } pthread_create(&send_thread, NULL, send_message, (void*)sock); pthread_create(&recv_thread, NULL, recv_message, (void*)sock); pthread_join(send_thread, &thread_result); pthread_join(recv_thread, &thread_result); close(sock); return 0; }
컴파일 했더니...
/tmp/ccy4sDIQ.o(.text+0x16e): In function `main':
: undefined reference to `error_handling'
collect2: ld returned 1 exit status
이렇게 나오네요...
Forums:
서버: void
서버:
void send_message(char *message, int len) 함수를
void *clnt_connection(void *arg)함수 위로 올려주세요.
pthread_mutex_t mutx; 하고 void *clnt_connection(void *arg) 사이로 넣어주시면 됩니다.
클라이언트 :
코드를 아무리 훓어보아도 error_handling()함수가 보이지 않습니다. 코드를 다시 확인해봐주세요.
fs.c:70: warning:
fs.c:70: warning: `send_message' was previously implicitly declared to return `int'
-> void로 선언되었음에도 불구하고 return 0; 라는 int형을 리턴해주고 있습니다. return 0;를 없애주면 error가 아닌 warning이 사라지구요... (error는 없고 모두 warning입니다. 즉 컴파일은 하겠지만 주의해서 체크해봐라..라는 경고 문구죠. 참고로 warning은 숨겨진 버그의 시작이라고 생각하시고 끝까지 잡으세요 ^^)
또한 send_message function을 clnt_connection function위에 올리세요.
서버쪽 코드를
서버쪽 코드를 보니...인터넷의 socket programming source로 시험해보고자 하신것 같습니다.
구글에게 물어보니 비슷한 소스가 존재하네요.
서버쪽 error_handling함수는 다음과 같이 생겼으니 main함수 위에 선언하셔서 쓰시면 될것 같습니다.
stderr에 대해 궁금하시다면 man page를 참고해보세요.
본문을 읽어보니
본문을 읽어보니 책으로 공부하고 계시는군요..
모든 warning/error message를 잘 읽어보시고 해석하세요. 초보시절 애써 입력한 코드가 동작을 안하고 외계어-_-를 뿌려대며 컴파일이 안되면 살짝 패닉에 빠지는것은 이해합니다만, 이것들을 잡으려면 반드시 컴파일러가 뿌려주는 메시지를 번역하셔야 합니다. 컴파일러의 목소리에 귀를 기울이세요.
댓글 달기