我有一个服务器/客户端应用程序,有 2 个不同的版本。在第一个客户端读取一个文本文件并将文本数据发送到服务器,服务器将接收到的数据写入一个新的文本文件(“received.txt”),并且当它完成写入时,它将文本文件打印到屏幕上。
在第二个版本中,客户端做同样的事情,但我希望服务器在写入文件“received.txt”的同时将数据打印到屏幕上。你可能想知道我为什么要做这样的事情。我想加快写入文件并将文件打印回屏幕的过程。如果我使用 2 个线程,我可能会加快工作速度。
我遇到了一个问题,(这是我第一次使用pthreads)。服务器在将数据打印到屏幕之前终止。我认为这是关于调度的。当新创建的线程正在运行并且主线程被阻塞时,该文件没有可读取的内容,然后新创建的线程终止。这就是我对这个问题的猜测。如果可能的话,我想在这里实现的是同时进行读/写。如果我做错了,或者我不能用线程同时读/写,请告诉我:)
这是服务器(第二版):
#include <stdio.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <pthread.h>
#include <time.h>
void error(char *msg) {
perror(msg);
exit(1);
}
//New Thread function
void *printData() {
FILE *fp = fopen("received.txt" , "r");
char buffer;
time_t time1 = time(NULL);
if( fp != NULL ) {
while( ( buffer = fgetc(fp)) != NULL ) {
printf("%c" , buffer);
}
fclose(fp);
}
time_t time2 = time(NULL);
double diff = difftime(time2 , time1);
printf("It took %.lf seconds.\n" , diff);
pthread_exit(NULL);
}
int main(int argc , char *argv[]) {
int sockfd , newsockfd , port_no , cli_length , n;
char buffer[256];
struct sockaddr_in server_addr , client_addr;
FILE *fp;
int thread_Created = 0;
pthread_t thread;
if(argc < 2) {
fprintf(stderr , "ERROR , no port provided!");
exit(1);
}
sockfd = socket(AF_INET , SOCK_STREAM , 0);
if( sockfd < 0 )
error("ERROR opening socket.");
bzero( (char *) &server_addr , sizeof(server_addr) );
port_no = atoi(argv[1]);
server_addr.sin_family = AF_INET;
server_addr.sin_port = htons( port_no );
server_addr.sin_addr.s_addr = INADDR_ANY;
if( bind( sockfd , (struct sockaddr *) &server_addr , sizeof(server_addr)) < 0 ) {
error("ERROR on binding.");
}
listen(sockfd , 5);
cli_length = sizeof(&client_addr);
newsockfd = accept( sockfd , (struct sockaddr *) &client_addr , &cli_length );
if (newsockfd < 0 )
error("ERROR on accept.");
bzero(buffer , 256);
if( (fp = fopen("received.txt" , "w")) != NULL ) {
while( (n = read(newsockfd , buffer , 255)) != 0 ) {
int i = 0;
for(i = 0 ; i < 255 ; i++) {
if( buffer[i] != '\0')
fputc(buffer[i] , fp);
}
//Create a new thread to read the file and print the results
if( !thread_Created ) {
pthread_create( &thread , NULL , printData , NULL );
thread_Created = 1;
}
}
}
fclose(fp);
/* while(pthread_kill(thread , 0 ) == 0 ) { */
/* } */
}