在Linux中,使用fprintf
實現異步日志記錄需要結合線程和緩沖區
#define LOG_BUFFER_SIZE 4096
char log_buffer[LOG_BUFFER_SIZE];
#include <pthread.h>
pthread_mutex_t log_mutex = PTHREAD_MUTEX_INITIALIZER;
#include <stdarg.h>
#include<string.h>
void async_log(const char *format, ...) {
va_list args;
char log_entry[256];
int log_entry_len;
// 格式化日志條目
va_start(args, format);
log_entry_len = vsnprintf(log_entry, sizeof(log_entry), format, args);
va_end(args);
// 將日志條目添加到緩沖區
pthread_mutex_lock(&log_mutex);
if (log_entry_len + strlen(log_buffer) < LOG_BUFFER_SIZE) {
strcat(log_buffer, log_entry);
} else {
// 緩沖區已滿,處理緩沖區中的日志信息
// ...
}
pthread_mutex_unlock(&log_mutex);
}
#include <unistd.h>
void *log_thread(void *arg) {
FILE *log_file = fopen("log.txt", "a");
if (!log_file) {
perror("Failed to open log file");
return NULL;
}
while (1) {
pthread_mutex_lock(&log_mutex);
if (strlen(log_buffer) > 0) {
fprintf(log_file, "%s", log_buffer);
log_buffer[0] = '\0';
}
pthread_mutex_unlock(&log_mutex);
usleep(100000); // 每隔100ms檢查一次緩沖區
}
fclose(log_file);
return NULL;
}
#include <pthread.h>
int main() {
pthread_t log_tid;
pthread_create(&log_tid, NULL, log_thread, NULL);
// 調用異步日志記錄函數
async_log("This is a log entry\n");
// 等待日志線程完成
pthread_join(log_tid, NULL);
return 0;
}
這樣,你就實現了一個簡單的異步日志記錄功能。請注意,這個示例僅用于演示目的,實際應用中可能需要進行更多的錯誤處理和優化。