Linux下undefined reference to ‘pthread_create’问题解决
生活随笔
收集整理的這篇文章主要介紹了
Linux下undefined reference to ‘pthread_create’问题解决
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
Linux下undefined reference to ‘pthread_create’問題解決
在試用Linux 線程模塊時,試用pthread_create 函數。
編譯命令為?gcc main.c -o test時,會出現如下錯誤
? 問題的原因:pthread不是linux下的默認的庫,也就是在鏈接的時候,無法找到phread庫中該函數的入口地址,于是鏈接會失敗。
解決:在gcc編譯的時候,附加要加?-lpthread參數即可解決。
試用如下命令即可編譯通過
gcc main.c -o test -lpthread如下編譯通過?
#include<stdlib.h> #include<stdio.h> #include<string.h> #include<sys/types.h> #include<sys/socket.h> #include<arpa/inet.h> #include<netinet/in.h> #include<unistd.h> #include <signal.h> #include <sys/wait.h> #include <pthread.h>#define N 128void handler(int sig){wait(NULL); }typedef struct{struct sockaddr_in addr;int acceptfd; }MSG;void *pthread_fun(void *arg){int count = 0;ssize_t bytes;MSG msg = *(MSG *)arg; char buf[N] = "666";char text[N] = "";while(1){// 打印客戶端信息printf("ip:%s, port:%d\n", inet_ntoa(msg.addr.sin_addr), ntohs(msg.addr.sin_port));// 接收數據if((count = recv(msg.acceptfd,text,N,0))==-1){perror("fail to recv");exit(1);}else if(count == 0){printf("The client quited\n");pthread_exit(NULL);}printf("from client: ");for(int j=0;j<count;j++){printf("%c",text[j]);}printf("\n");//發送buf數據if(send(msg.acceptfd,buf,sizeof(buf),0)==-1){perror("fail to send");exit(1);}} }int main(int argc, char const * argv[]){if(argc < 3){fprintf(stderr, "server Usage:%s ip port\n",argv[0]);exit(1);}int sockfd;// 創建tcp套接字if((sockfd=socket(AF_INET,SOCK_STREAM,0)) == -1){perror("fail to socket");exit(1);}struct sockaddr_in serveraddr;socklen_t addrlen = sizeof(serveraddr); serveraddr.sin_family = AF_INET; // 協議族 AF_INET:ipv4網絡協議// inet_addr: 將點分十進制字符串ip地址轉為整形數據serveraddr.sin_addr.s_addr = inet_addr(argv[1]); // ip地址// atoi 將數字型字符串轉換為整形數據// htons 將主機字節序轉化為網絡字節序serveraddr.sin_port = htons(atoi(argv[2]));// 將套接字和網絡信息綁定if(bind(sockfd,(struct sockaddr*)&serveraddr, addrlen) == -1){perror("fail to connect");exit(1);};// 將套接字設置為監聽狀態if(listen(sockfd,5) == -1){perror("fail to listen");exit(1);}struct sockaddr_in clientsock;addrlen = sizeof(clientsock);printf("準備阻塞...\n");// 使用信號,異步的方式處理僵尸進程signal(SIGCHLD,handler);while(1){ // 阻塞等待客戶端的鏈接int clisock = accept(sockfd,(struct sockaddr*)&clientsock, &addrlen);// 創建子線程與客戶端通信MSG msg;msg.addr = clientsock;msg.acceptfd = clisock;pthread_t thread;if(pthread_create(&thread,NULL,pthread_fun,&msg)!=0){perror("fail to pthread_create");}pthread_detach(thread);}// 關閉套接字描述符//close(clisock);//close(sockfd);return 0; }?
總結
以上是生活随笔為你收集整理的Linux下undefined reference to ‘pthread_create’问题解决的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 常考数据结构与算法:两个链表的第一个公共
- 下一篇: webserver通信过程