gpt4 book ai didi

c - 特定于线程的数据

转载 作者:塔克拉玛干 更新时间:2023-11-03 01:54:02 25 4
gpt4 key购买 nike

我有一个客户端程序如下,我需要让它成为多线程的,即每个连接一个线程。但是变量 sockfd 将在一个线程中保持全局。我明白要做到这一点,我需要使用 pthread_key_t、pthread_key_create...等。但是,我很困惑如何使用它。如果有任何帮助,我将不胜感激。

int sockfd;
pthread_key_t key_to_sockfd;

void error(const char *msg)
{
perror(msg);
exit(0);
}


void set_connection(char *argv[])
{

int portno;
struct sockaddr_in serv_addr;
struct hostent *server;

char buffer[256];
portno = atoi(argv[2]);
sockfd = socket(AF_INET, SOCK_STREAM, 0);
if (sockfd < 0)
error("ERROR opening socket");
server = gethostbyname(argv[1]);
if (server == NULL) {
fprintf(stderr,"ERROR, no such host\n");
exit(0);
}
bzero((char *) &serv_addr, sizeof(serv_addr));
serv_addr.sin_family = AF_INET;
bcopy((char *)server->h_addr,
(char *)&serv_addr.sin_addr.s_addr,server->h_length);
serv_addr.sin_port = htons(portno);
if (connect(sockfd,(struct sockaddr *) &serv_addr,sizeof(serv_addr)) < 0)
error("ERROR connecting");
return;
}

void send_message()
{
char buffer[256];
int i=0,n;
do{
printf("Please enter the message: ");
bzero(buffer,256);
fgets(buffer,255,stdin);
n = write(sockfd,buffer,strlen(buffer));
if (n < 0)
error("ERROR writing to socket");
i++;
}while(i<3);
bzero(buffer,256);
n = read(sockfd,buffer,255);
if (n < 0)
error("ERROR reading from socket");
printf("%s\n",buffer);
return;
}

void disconnect()
{
close(sockfd);
return;
}

void client_thrd(char *argv[])
{
set_connection(argv);
send_message();
disconnect();
}
int main(int argc, char *argv[])
{

pthread_t thid[2];
int i;
void *status;
if (argc < 3) {
fprintf(stderr,"usage %s hostname port\n", argv[0]);
exit(0);
}
for(i=0;i<1;i++)
pthread_create(&thid[i],NULL,(void*)&client_thrd,(void*)argv);
for(i=0;i<1;i++)
pthread_join(thid[i],&status);


return 0;
}

我已经为一个线程执行了程序并且工作正常。但是当我将线程数增加到一个以上时,它当然不起作用,因为全局变量 sockfd。这是一个更大的测试程序。

感谢和问候

最佳答案

使用起来非常简单。你打电话pthread_key_create(&key_to_sockfd, NULL)在程序开始时,然后在每个线程中,您将看到一个初始值 NULL。使用函数 pthread_setspecific(key_to_sockfd, <pointer to a struct which contains sockfd>)在每个线程中。

从那时起,每个线程都会看到一个指向包含您的 sockfd 的结构的不同指针。当你的线程完成它时,你删除结构并使用 pthread_setspecific(key_to_sockfd, NULL)

线程完成后调用pthread_key_delete(key_to_sockfd)删除存储。您还可以通过向 pthread_key_create 提供回调函数来自动清理在线程结束时释放内存。

关于c - 特定于线程的数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7411774/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com