主頁 > 知識庫 > linux下C語言實(shí)現(xiàn)寫日志功能

linux下C語言實(shí)現(xiàn)寫日志功能

熱門標(biāo)簽:外呼系統(tǒng)坐席費(fèi)計(jì)入會計(jì)哪個科目 如何分析地圖標(biāo)注 大連400電話如何申請 新余高德地圖標(biāo)注怎么修改 電銷機(jī)器人價值 高德地圖標(biāo)注好做嗎 撫順地圖標(biāo)注 達(dá)亞電銷機(jī)器人官網(wǎng) 電銷機(jī)器人怎么接線路

先上程序,該程序經(jīng)過測試能夠很好的實(shí)現(xiàn)寫日志要求

/*************************************************************************
  > File Name: log.c
  > Author: 
 ************************************************************************/
#include <stdio.h>
#include <sys/types.h> 
#include <unistd.h> 
#include <stdlib.h>
#include <string.h>
#include <errno.h>
#include <stdarg.h>
#include <time.h>
#include <pthread.h>

int safe_asprintf(char **strp, const char *fmt, ...);
int safe_vasprintf(char **strp, const char *fmt, va_list ap);
void plog(const char *format, ...) ;
void pinfo(const char *format, ...) ;

#define DEBUG

#ifdef DEBUG
void plog(const char *format, ...);
void pinfo(const char *format, ...);
#define debug(fmt, args...) plog(fmt, ##args) 
#else
#define debug(fmt, args...) do{}while(0)
#endif

static pthread_mutex_t fileMutex = PTHREAD_MUTEX_INITIALIZER;

int main(int argc, char *argv)
{
  return 0;
}

/*
 * safe_asprintf();
 */
int safe_asprintf(char **strp, const char *fmt, ...) 
{
  va_list ap;
  int retval;

  va_start(ap, fmt);
  retval = safe_vasprintf(strp, fmt, ap);
  va_end(ap);

  return retval;
}

/*
 * safe_vasprintf();
 */
int safe_vasprintf(char **strp, const char *fmt, va_list ap) 
{
  int retval;

  retval = vasprintf(strp, fmt, ap);
  if (retval == -1) 
  {
    printf("Failed to vasprintf: %s. Bailing out\n", strerror(errno));
    return 1;
  }
  return retval;
}

/*
 * plog();
 */
void plog(const char *format, ...) 
{

  pthread_mutex_lock(&fileMutex);

  FILE *fp = NULL;
  va_list vlist;
  char *fmt = NULL;

  // Open debug info output file.
  if (!(fp = fopen("log.txt", "a+"))) {
    pthread_mutex_unlock(&fileMutex);
    return;
  }

  va_start(vlist, format);
  safe_vasprintf(&fmt, format, vlist);
  va_end(vlist);
  if (!fmt) {
    pthread_mutex_unlock(&fileMutex);
    return;
  }

  time_t timep;
  struct tm *ptm = NULL;
  time(&timep);
  ptm = localtime(&timep);
  fprintf(fp, "[%04d-%02d-%02d-%02d-%02d-%02d] %s", 
      ptm->tm_year + 1900, 
      ptm->tm_mon + 1,
      ptm->tm_mday, 
      ptm->tm_hour, 
      ptm->tm_min, 
      ptm->tm_sec, 
      fmt);

  free(fmt);
  fsync(fileno(fp));
  fclose(fp);

  pthread_mutex_unlock(&fileMutex);
}

/*
 * pinfo();
 */
void pinfo(const char *format, ...) 
{
  pthread_mutex_lock(&fileMutex);

  FILE *fp = NULL;
  va_list vlist;
  char *fmt = NULL;

  // Open debug info output file.
  if (!(fp = fopen("log.txt", "a+"))) {
    pthread_mutex_unlock(&fileMutex);
    return;
  }

  va_start(vlist, format);
  safe_vasprintf(&fmt, format, vlist);
  va_end(vlist);
  if (!fmt) {
    pthread_mutex_unlock(&fileMutex);
    return;
  }

  fprintf(fp, "%s", fmt);

  free(fmt);
  fsync(fileno(fp));
  fclose(fp);

  pthread_mutex_unlock(&fileMutex);
}

程序?qū)崿F(xiàn)的日志格式為:

時間 + 空格 + 具體實(shí)現(xiàn)(自己的調(diào)試內(nèi)容)

本段程序值得學(xué)習(xí)的地方:

  1. va_list 結(jié)構(gòu)體的使用
  2. linux 的格式化輸出字符串
  3. 文件操作過程中pthread_mutex鎖的使用,以及他的優(yōu)點(diǎn)
  4. linux DEBUG 的應(yīng)用,方便調(diào)試

linux如何查看日志:

使用tail 命令可以實(shí)現(xiàn)日志的查詢,以及其他功能,不了解的話,自行查資料解決。

對上面應(yīng)用不明白的請自行查資料解決。

標(biāo)簽:湖南 遼源 楊凌 衡水 黃石 新鄉(xiāng) 海東 南通

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《linux下C語言實(shí)現(xiàn)寫日志功能》,本文關(guān)鍵詞  linux,下,語言,實(shí)現(xiàn),寫,日志,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《linux下C語言實(shí)現(xiàn)寫日志功能》相關(guān)的同類信息!
  • 本頁收集關(guān)于linux下C語言實(shí)現(xiàn)寫日志功能的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章