gpt4 book ai didi

c - 是否有可能在c中同时运行主线程及其子线程

转载 作者:塔克拉玛干 更新时间:2023-11-02 23:09:56 26 4
gpt4 key购买 nike

我必须使用 c 中的线程程序从服务器读取一些文件(日志)。该程序应该保持同时意味着一方面该子线程应该执行,同时主线程应该通知它的子进程的时间。

所以在示例程序中,我尝试在子线程中运行日志记录功能,同时父进程/父线程/主线程将打印运行日志记录的时间(以秒为单位)。

PS:我的问题是,如果我将使用 pthread_join(),那么第一个日志读取函数将执行,这实际上是由于无限循环而阻塞线程。而且我无法在主要功能中获得控制流。无论如何我想一起执行而不互相打扰。我在 Java 中使用线程和同步方法做过类似的事情。但是在C中我对多线程编程了解不多

目前我没有使用锁,因为我不想要停止/恢复条件,我唯一的要求是两个函数保持启动状态,同时运行而不相互交互。感谢您的帮助。

void process(FILE *FP, int sockfd);
int create_ma_header(char*, int, int, int, int);
void* t_main(void*);

int i;

int main(int argc, char** argv)
{
void* arg;
void* t_result;
if (argc != 2)
{
printf("usage: tcpcli <IPaddress>");
exit(0);
}
arg = (void*) argv[1];
pthread_t t;
pthread_attr_t t_attr;
pthread_attr_init(&t_attr);
printf("before calling pthread_create getpid: %d getpthread_self %u tid:%u\n",
getpid(), pthread_self(), syscall(SYS_gettid));
pthread_create(&t, &t_attr, t_main, (void*) argv[1]); //loging tread
/* if(pthread_join(t,&t_result) != 0)
{
printf("Thread not joined \n");
exit(1);
}
*/
printf("Thread joined and status is Logs are getting printed what else you want to do .... \n");
while (1)
{
printf(
"Running time of log reading displayed from main thread: %d seconds",
i++);
slep(1);
}
pthread_exit(0);
}

void* loging_thread(void* arg)
{
char* server_ip;
server_ip = (char*) arg;
int sockfd;
struct sockaddr_in servaddr;
sockfd = socket(AF_INET, SOCK_STREAM, 0);
bzero(&servaddr, sizeof(servaddr));
servaddr.sin_family = AF_INET;
servaddr.sin_port = htons(SERV_PORT);
inet_pton(AF_INET, server_ip, &servaddr.sin_addr);

printf(
"in loging_thread log has been redirected to log_read.dat getpid: %d getpthread_self %u tid:%u\n",
getpid(), pthread_self(), syscall(SYS_gettid));
connect(sockfd, (struct sockaddr *) &servaddr, sizeof(servaddr));
process(stdin, sockfd); /* do it all */
pthread_exit(0);
}

void process(FILE *fp, int sockfd)
{
FILE* log_f;
int fd;
fd = open("log_read.dat", O_CREAT | O_WRONLY, 0644);
char sendline[MAXLINE];
char reply[MAXLINE], string2[MAXLINE], *body;
char *p1, *p2, *p3;
create_ma_header(reply, 999, 999, VERSION, 999);
write(sockfd, reply, sizeof(reply));
while (1)
{
char header[SDNS_MA_HEADERSZ];
read(sockfd, body, size);
write(fd, body, size);
}
}

int create_ma_header(char * reply, int type, int size, int version, int lic)
{
sprintf(reply, "%4d%c%10d%c%4d%c%4d", type, SD_PIPE, size, SD_PIPE, version,
SD_PIPE, lic);
if (strlen(reply) != 26 - 1)
{

return 0;
}
reply[strlen(reply)] = SD_PIPE;
return 1;
}

char * get_ma_header(char *curr_p, int *type_p, int *size_p, int *version_p,
int *lic_p)
{
*type_p = (int) strtol(curr_p, NULL, 10);
curr_p += 5;
*size_p = (int) strtol(curr_p, NULL, 10);
curr_p += 11;
*version_p = (int) strtol(curr_p, NULL, 10);
curr_p += 5;
*lic_p = (int) strtol(curr_p, NULL, 10);
curr_p += 5;
return curr_p;
}

最佳答案

您似乎误解了 pthread_createpthread_join 的作用。

pthread_create 之后,您将有两个并行运行的线程。你不需要做更多的事情让他们都做他们做的事。两个线程都“没有控制权”,它们只是都存在。

当线程“B”完成它需要做的任何事情时,它可以“返回”一个值。线程“B”然后停止运行(任何事情),但返回值会被存储起来,直到需要它为止。

另一个线程“A”可以通过运行 pthread_join 从已完成的线程中检索返回值。如果线程“B”实际上尚未完成(它仍在运行),则 pthread_join 将阻塞线程“A”,直到线程“B”完成并返回一个值。

因此,在永不退出的线程“B”上调用pthread_join 是错误的。

使用pthread_join有两个原因:

  1. 获取返回值。
  2. 确保程序不会在所有线程完成之前退出。

因此,在您的程序中您根本不需要 pthread_join

关于c - 是否有可能在c中同时运行主线程及其子线程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19706773/

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