首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

C语言 | C++打印有效日志

引言 在日常代码测试或运行中,打印日志检测代码运行状态必不可少。...先举三个例子: 在物联网系统中设备什么时候上线,可以将上线的信息写入数据库,也可以将该设备上线的记录打印日志中,以该设备的id为文件名,查找日志也比较方便,上线时间、IP地址等打印到文本中。...在复杂的多环节系统中,快速定位问题问题出错的环节,将各个系统数据接口的数据打印日志,如果有返回值可以判断执行是否成功,可以只打印错误的日志,出现问题时查看日志文件就可以定位是那个环节。...在异常捕获中将错误的信息打印日志文件,快速查看代码或数据出现的问题。 日志的作用 一般程序日志出自下面几个方面的需求: 记录用户操作的审计日志,甚至有的时候就是监管部门的要求。...而且,最好在打印日志时输出英文,防止中文不支持而打印出乱码的情况。 日志的性能 无论我们把日志写到文件还是数据库,都需要消耗IO资源。适当的控制日志的输出也有利于提高程序的性能。

1.9K88
您找到你想要的搜索结果了吗?
是的
没有找到

linuxC语言实现写日志功能

先上程序,该程序经过测试能够很好的实现写日志要求 /************************************************************************* >...File Name: log.c > Author: ************************************************************************...(fp, "%s", fmt); free(fmt); fsync(fileno(fp)); fclose(fp); pthread_mutex_unlock(&fileMutex); } 程序实现的日志格式为...: 时间 + 空格 + 具体实现(自己的调试内容) 本段程序值得学习的地方: va_list 结构体的使用 linux 的格式化输出字符串 文件操作过程中pthread_mutex锁的使用,以及他的优点...linux DEBUG 的应用,方便调试 linux如何查看日志: 使用tail 命令可以实现日志的查询,以及其他功能,不了解的话,自行查资料解决。

1.8K31

如何打印日志

如何打印日志 日志打印对研发来说,是很有必要的, 如何打印日志,让日志能反映出处理流程,让日志能反映出问题所在,这个很重要,不好的日志,会加大研发排查问题的难度,过多的日志也会对研发造成干扰,如何打印日志...日志存在的问题 安全问题 将用户的敏感信息打印在了日志日志级别不合理 warning日志较为泛滥,且少有人关注 部分阻塞业务流程的错误,未正确使用error日志 错误日志重复打印 同一个错误在不同的位置重复打印...除外) 【建议】谨慎的使用日志进行打点 合理分级 【强制】日志打印时应选择合适的级别 保证安全 【强制】原则上禁止日志汇总禁止打印用户L4级别的日志 【强制】日志打印满足飞书日志打印安全规范 【建议】使用合适的脱敏方式对敏感信息进行脱敏...MQ消息的唯一标记MsgID 案例二:日志打印时未传入ctx导致日志缺乏logID,无法通过logID检索到该日志 案例三:在程序的关键分岔点未打印日志 案例四:在特殊的条件分岔未打印日志 【强制】关键日志必须打印路径...,打印日志必须带上关键信息 【强制】日志打印时必须携带logID

36120

聊聊日志打印日志审计

二.日志切面 ​ springboot中默认提供的日志打印功能无法打印函数的入参与出参信息。现在如果有个bug在生产环境可以复现,测试环境怎么也复现不了,本地代码又无法连接生产环境进行调试。...生产环境一般一般情况下指挥打印info级别的日志。这个时候就头疼了,无法定位解决问题。 ​ 因此线上环境能有一个功能帮我们打印函数的详细的入参或者出参这个功能是很重要的。...当然这个功能默认情况下还是不要开启,毕竟大多数线上环境的调用链封装比较深,出参与入参信息打印会比较多,对于日志的存储会是一个比较大的问题。...>[] excludeReturnClass; //不进行日志打印的类 private static final Class clazz) { return Arrays.stream(excludeClass) .anyMatch(c -> c.isAssignableFrom

2.3K10

c语言中的常见图形打印

前言 个人主页: :✨✨✨初阶牛✨✨✨ 推荐专栏: c语言初阶 个人信条: 知行合一 本篇简介:>:介绍c语言中的三角形与菱形打印分步介绍 效果展示图: 目录 前言 一、等腰三角形...2*i-1;j++)//打印每行的元素个数 { printf("*"); } printf("\n");//每打印一行换行 } return 0; } 效果图: (2)打印空格...: 为了美观,我们需要在打印每行元素之前打印适当数量的空格,那么,每行打印多少空格呢?...通过观察,我们可以发现,空格数=需要打印的行数-所在行,即 例如: 打印5行是,空格数分别为 第一行:4(空格数)=5(需要打印的行数)-1(所在行) 第二行:5-2 第三行:5-3 第四行...与紧凑型元素个数是一样打印的,不同之处在于: 打印每个元素后用空格隔开: 打印空格数发生变化,应当为原来的两倍.

1.8K50

Ijkplayer打印FFMpeg日志

背景 在打印Ijkplayer播放日志的过程中,在ijkplayer中日志可以正常输出。...但是涉及到FFMpeg的日志,则无法输出 原因 由于FFMPeg中的libavutil/log.c中使用的是fprintf,所以输出到了标准输出中,而Android有自己的一套输出日志的端口。...armv7a编译的是/ijkplayer/android/contrib/ffmpeg-armv7a路径下的ffmpeg库,而不是extra下面的ffmpeg 在ijkplayer的ff_player.c中的...ffp_global_init通过av_log_set_callback注册好回调函数,然后即可通过该函数将ffmpeg库中的输出重定向到ijkplayer中 这步完成后,发现还是打印不出来日志...最后,一怒之下,把ijksdl_log.h中的日志打印都换成了android jni的日志打印,就打印出来了 #ifdef EXTRA_LOG_PRINT #define VLOG(level, TAG

2.3K30

C语言打印彩色字符,还能闪烁!

ANSI escape code 最近在研究日志打印组件easylogger,玩转各种彩色日志打印不亦乐乎,好奇心越来越重,遂深入研究,发现了一个非常神奇的东西:ANSI escape code!...① 打印没有背景色,字体颜色为绿色,字体正常的字符: printf("\033[32mHelloWorld\r\n"); 编译下载,即可看到效果: ?...② 及时取消属性 设置属性之后,该属性在终端中一直存在,必须要及时取消,比如在刚刚的printf之后,继续正常打印,不加特殊字符,依然会打印绿色字符: printf("\033[32mHelloWorld...③ 多个特殊字符一起设置 比如这里我同时设置打印颜色为绿色,字体在终端闪烁: printf("\033[32;5mHelloWorld\033[0m\r\n"); ?...怎么样,在终端打印各种好玩的字符是不是非常简单~自己上手玩玩吧!

2K10

如何打印日志

1.选择恰当的日志级别 error warn info debug 2.日志打印出参入参数 方便甩锅 3.选择合适的日志格式 时间戳 线程名字 日志级别等 4.if-else ,switch 等分支语句都建议打印日志...,方便排查 5.对一些比较低的日志级别进行判断,使用log.isXXXX()方法判断 如果日志不被记录,但是日志内的字符拼接,对象的toString方法也会执行,浪费性能 6.不建议直接使用log4j...,logback等日志系统,建议使用slf4j框架,方便统一处理 7.建议使用参数占位符{},而不是+拼接,简洁且提升性能 8.建议使用异步日志,能有效提升IO性能 9.不要使用e.printStackTrace...()打印错误信息,因为太多信息,且是堆栈信息,会使得内存溢出 10.异常不要只打一半,要完成输出 11.禁止在线上开启debug 会把磁盘打满 12.不要记录了异常,又抛出异常 13.避免重复打印日志...,浪费磁盘空间 14.日志文件分离,不同级别日志存放在不同文件中 15.核心功能模块,建议打印详细的日志

7110
领券