-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.c
120 lines (107 loc) · 4.15 KB
/
main.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
/* -*- Mode: C; indent-tabs-mode: t; c-basic-offset: 4; tab-width: 4 -*- */
/*
* main.c
* Copyright (C) 2016 Gavin Chan <jiajun.chen@ww-it.cn>
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* 3. Neither the name ``Gavin Chan'' nor the name of any other
* contributor may be used to endorse or promote products derived
* from this software without specific prior written permission.
*
* logtest-sample IS PROVIDED BY Gavin Chan ``AS IS'' AND ANY EXPRESS
* OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL Gavin Chan OR ANY OTHER CONTRIBUTORS
* BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
* BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
* OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#include "libplog.h"
#include <pthread.h>
#include <stdio.h>
#include <memory.h>
#include <stdarg.h>
#define THRD_COUNT 20
#define MSG_SIZE 898
/*
* @description:调用log_print(),传入调试级别码
*/
#define PLOG_DEBUG(msg, args...) \
log_print(__FILE__, __FUNCTION__, __LINE__, DEBUG, msg, ##args)
/*
* @description:调用log_print(),传入提示级别码
*/
#define PLOG_INFO(msg, args...) \
log_print(__FILE__, __FUNCTION__, __LINE__, INFO, msg, ##args)
/*
* @description:调用log_print(),传入警告级别码
*/
#define PLOG_WARN(msg, args...) \
log_print(__FILE__, __FUNCTION__, __LINE__, WARN, msg, ##args)
/*
* @description:调用log_print(),传入错误级别码
*/
#define PLOG_ERROR(msg, args...) \
log_print(__FILE__, __FUNCTION__, __LINE__, ERROR, msg, ##args)
/*
* @description:调用log_print(),传入崩溃级别码
*/
#define PLOG_FATAL(msg, args...) \
log_print(__FILE__, __FUNCTION__, __LINE__, FATAL, msg, ##args)
void log_print(const char *file_name, const char *func_name,
const int line, log_level_t level, char *fmt, ...)
{
size_t len = 0;
char msg[MSG_SIZE];
/* snprintf和vsnprintf,如果大于MAX_SIZE将被截断 */
snprintf(msg, MSG_SIZE, "`%s`%s:%d %s\t", func_name,
file_name, line, get_level(level));
va_list arg_ptr;
va_start(arg_ptr, fmt);
len = strlen(msg);
vsnprintf(msg + len, MSG_SIZE - len, fmt, arg_ptr);
libplog_write(level, msg);
va_end(arg_ptr);
}
void *
print_log(void *arg)
{
for(int i = 0; i < 1000; ++i)
{
PLOG_ERROR("我是测试字符串 %s,第 %d次打印,我是线程%s\n","张鹏",i, (char *)arg);
PLOG_DEBUG("我是测试字符串 %s,第 %d次打印,我是线程%s\n","灿灿",i, (char *)arg);
PLOG_INFO("我是测试字符串 %s,第 %d次打印,我是线程%s\n","何敏",i, (char *)arg);
PLOG_FATAL("我是测试字符串 %s,第 %d次打印,我是线程%s\n","小华",i, (char *)arg);
PLOG_WARN("我是测试字符串 %s,第 %d次打印,我是线程%s\n","小玲",i, (char *)arg);
}
return NULL;
}
int
main()
{
pthread_t thrd[THRD_COUNT];
char thrdname[20][10]={"thread-A","thread-B","thread-C","thread-D","thread-E","thread-F","thread-G","thread-H","thread-I","thread-J",
"thread-K","thread-L","thread-M","thread-N","thread-O","thread-P","thread-Q","thread-R","thread-S","thread-T"};
libplog_init (".", "test", 10, 1, DEBUG);
for(int j = 0; j < THRD_COUNT; ++j)
{
pthread_create(&thrd[j], NULL, print_log, (void *)thrdname[j]);
}
for(int j = 0; j < THRD_COUNT; ++j)
{
pthread_join(thrd[j], NULL);
}
libplog_destroy ();
return (0);
}