1.编程实现输入信息到文件
(做一个日志作用)
在这里也是展示了va_list和vfprintf的使用
#include <stdio.h>
#include "log.h"
#include <stdarg.h>
#include <stdio.h>
#include <sys/time.h>
#include <time.h>
int gettimeofday(struct timeval *tv, struct timezone *tz);
FILE *g_log = NULL;
void log_crate() { g_log = fopen("data.txt", "a+"); }
void log_destroy() {
close(g_log);
g_log = NULL;
}
void log_write(char *format, ...) {
va_list ap;
char string[128] = {'\0'};
struct timeval tv;
struct tm *gmt, *area;
gettimeofday(&tv, 0);
area = localtime(&(tv.tv_sec));
//sprintf(string,"Time is: %s %u:%u", asctime(area), tv.tv_sec, tv.tv_usec);
sprintf(string,"Time is: %s ", asctime(area));
va_start(ap, format);
vfprintf(g_log, format, ap);
vfprintf(g_log,string,ap);
va_end(ap);
}
然后搭建了一个基于tcp的服务器和客户机
客户机
#include <stdio.h>
#include "log.h"
#include <sys/types.h> /* See NOTES */
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include<string.h>
void client(char *a,char *b) {
int s_fd;
int c_fd;
char writebuf[128]={'\0'};
char readbuf[128]={'\0'};
strcpy(writebuf,"hello from client\n");
int len;
c_fd = socket(AF_INET, SOCK_STREAM, 0);
struct sockaddr_in c_addr;
c_addr.sin_family = AF_INET;
c_addr.sin_port = htons(atoi(b));
inet_aton(a, &c_addr.sin_addr);
len = sizeof(struct sockaddr_in);
connect(c_fd,(struct sockaddr*)&c_addr,len);
printf("addr=%s\n", inet_ntoa(c_addr.sin_addr));
write(c_fd,writebuf,strlen(writebuf));
read(c_fd,readbuf,sizeof(readbuf));
printf("readbuf=%s\n",readbuf);
while(1);
}
int main(int argc, char **argv) {
client(argv[1],argv[2]);
return 0;
}
服务器
#include <stdio.h>
#include "log.h"
#include <sys/types.h> /* See NOTES */
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include<string.h>
void server(char *a, char *b) {
int s_fd;
int c_fd;
int len;
char writebuf[128]={'\0'};
char readbuf[128]={'\0'};
strcpy(writebuf,"helloc form server\n");
s_fd = socket(AF_INET, SOCK_STREAM, 0);
struct sockaddr_in s_addr;
struct sockaddr_in c_addr;
s_addr.sin_family = AF_INET;
s_addr.sin_port = htons(atoi(b));
inet_aton(a, &s_addr.sin_addr);
bind(s_fd, (struct sockaddr *)&s_addr, sizeof(struct sockaddr_in));
listen(s_fd, 10);
len = sizeof(struct sockaddr_in);
c_fd = accept(s_fd, (struct sockaddr *)&s_addr, &len);
printf("addr=%s\n", inet_ntoa(c_addr.sin_addr));
write(c_fd, writebuf, strlen(writebuf));
read(c_fd, readbuf, sizeof(readbuf));
printf("readbuf=%s\n", readbuf);
while (1)
;
}
int main(int argc, char **argv) {
server(argv[1], argv[2]);
return 0;
}