首页
学习
活动
专区
圈层
工具
发布

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

引言 在日常代码测试或运行中,打印日志检测代码运行状态必不可少。...先举三个例子: 在物联网系统中设备什么时候上线,可以将上线的信息写入数据库,也可以将该设备上线的记录打印到日志中,以该设备的id为文件名,查找日志也比较方便,上线时间、IP地址等打印到文本中。...在复杂的多环节系统中,快速定位问题问题出错的环节,将各个系统数据接口的数据打印日志,如果有返回值可以判断执行是否成功,可以只打印错误的日志,出现问题时查看日志文件就可以定位是那个环节。...占用磁盘空间 通常,我们都是把日志写入磁盘上的日志文件中。适当的使用滚动日志并且定时清除旧文件是有好处的。我见过这样一个例子,程序运行几次后就跑不起来了,前几次都是正常的。...日志格式 常见的日志格式中对于每一条日志应含有的信息包括日期、时间、日志级别、代码位置、日志内容、错误码等信息。

2.6K88

C语言使用宏定义控制日志输出

这段代码演示了如何在C语言程序中灵活地控制调试信息的输出,这对于软件开发和调试阶段非常有用。...灵活性与可维护性:这种通过宏定义控制日志输出的方式,提供了一种灵活的机制来调整程序的调试级别。不需要修改代码中的每一个打印语句,只需简单修改宏定义即可全局控制日志的开关,便于维护和版本管理。...完整例子 下面是一个更完整的例子,展示如何在C语言程序中使用宏定义来控制不同级别的日志输出,包括调试(debug)、信息(info)、警告(warning)和错误(error)级别。...这允许开发者根据需要开启或关闭特定级别的日志输出,而无需修改代码中的日志语句。...\n"); // 重要,总是打印 return 0; } 在这个例子中,通过修改CURRENT_LOG_LEVEL的值,可以轻松地全局控制哪些级别的日志会被打印出来。

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

    【C语言】文件操作(中)

    C语言针对文件、画面、键盘等的数据输入输出操作都是通过流操作完成的。 一般情况下,我们想要向流里写入数据,或者从流里输入数据,都是要打开流,然后再操作。...我在上面提到过C语言针对文件、画面、键盘等的数据输入输出操作都是通过流操作完成的。可是我们在键盘上输入数据到程序中或者在屏幕上显示数据,好像并没有在代码中写所谓的打开流的操作啊!...C语言程序在启动时,默认打开三个标准流: stdin : 标准输入流。在大多数环境中从键盘输入数据,scanf函数就是从标准输入流里读取数据。 stdout : 标准输出流。...C语言中就是通过文件指针来维护流的各种操作。 2. 文件指针 学的深入的读者可能会提出一个这样的问题,文件是以何种形式在内存中存储的?...ANSI C规定使用fopen函数来打开文件,fclose来关闭文件。 两个函数的原型: fopen的返回值: 在fopen函数中,有一个形参const char* mode。

    53310

    C语言之指针(中)

    前言 承接同系列文章C语言之指针(上),本文将进一步介绍指针的相关知识。...首字符的地址放到了pstr中,而并非将整个字符串内容放入pstr中。 2.例子 int main() { char str1[] = "hello bit....return 0; } 没错,它表示的是数组指针数组(存放数组指针的数组) ---- 总结 以上就是今天要讲的内容,本文介绍了C语言中指针的相关知识,主要包括有字符指针、指针数组、数组指针、数组参数与指针参数...但由于篇幅原因,在这一篇文章中仍不能将所有的知识全部总结完,因此后续还是会不断补充关于C语言中的指针的内容,希望大家继续支持。...本文的作者也只是一个正在学习C语言等编程知识的萌新,若这篇文章中有哪些不正确的内容,请在评论区向作者指出(也可以私信作者),欢迎大佬们指点,也欢迎其他正在学习C语言的萌新和作者进行交流。

    1.1K20

    【C语言】C语言零基础纯干货教学(中)

    三、分支和循环 1、if语句 (1)if if(a) b; 括号内表达式a如果为真,则执行b语句,如果为假,则不执行 C语言中0表示假,非0表示真 (2)else if(a) b; else...= 跟我们平常用的不同,= 在C语言中是赋值的意思,==才是判断相等的意思 !...,但按照c语言的结构来说,先比较a和b,ac>0此表达式整个就返回真 所以我们采用以下写法 a c; &&是与的意思,需要两个条件同时成立整个表达式才返回真...:|| int a = 0; if(a = 0 || a = 1 || a = 2) { b; } 这里变量a只有取到0或1或2时才执行b,否则不执行 (4)简单例题:判断闰年 相信所有接触过C语言的同学在老师上课或者自学的过程中都会遇到这个问题...printf("three\n"); break; default: printf("other nums\n"); } return 0; } 6、while循环 (1)基本概念 C语言提供了三种循环语句

    66110

    C语言C++中assert的用法

    断言assert原型 void assert(int expression); assert宏的原型定义在中,其作用是先计算表达式expression的值为假(即为0),那么它就先向...不能使用改变环境的语句,就像我们上面的代码改变了i变量,在实际编写代码的过程中是不能这样做的; 例如: assert(i++ < 100) 不好:这是因为如果出错,比如在执行之前i=100,那么这条语句就不会执行...保持原信息内容不变 nNewSize<=0表示清除缓冲区 assert(nNewSize >= 0); assert(nNewSize <= MAX_BUFFER_SIZE); ... } 在我们使用C语言.../C++做工程项目时,如果我们能在代码中合理的使用assert,能使我们创建更稳定、质量更好且不易于出错的代码;当需要在一个值为FALSE时中断当前操作的话就可以使用断言。...单元测试必须使用断言;另外除了类型检查和单元测试外,断言还提供了一种确定各种特性是否在程序中得到维护的极好的方法;

    1.7K20

    C 语言 C++ 中 assert 的用法

    来源:公众号(c语言与cpp编程) 断言assert原型 void assert(int expression); assert宏的原型定义在中,其作用是先计算表达式expression...assert(nOffset >= 0); assert(nOffset+nSize <= m_nInfomationSize); 不能使用改变环境的语句,就像我们上面的代码改变了i变量,在实际编写代码的过程中是不能这样做的...保持原信息内容不变 nNewSize<=0表示清除缓冲区 assert(nNewSize >= 0); assert(nNewSize <= MAX_BUFFER_SIZE); ... } 在我们使用C语言.../C++做工程项目时,如果我们能在代码中合理的使用assert,能使我们创建更稳定、质量更好且不易于出错的代码;当需要在一个值为FALSE时中断当前操作的话就可以使用断言。...单元测试必须使用断言;另外除了类型检查和单元测试外,断言还提供了一种确定各种特性是否在程序中得到维护的极好的方法;

    3.4K00

    C语言 | C++中assert的用法

    断言assert原型 void assert(int expression); assert宏的原型定义在中,其作用是先计算表达式expression的值为假(即为0),那么它就先向...不能使用改变环境的语句,就像我们上面的代码改变了i变量,在实际编写代码的过程中是不能这样做的; 例如: assert(i++ < 100) 不好:这是因为如果出错,比如在执行之前i=100,那么这条语句就不会执行...保持原信息内容不变 nNewSize<=0表示清除缓冲区 assert(nNewSize >= 0); assert(nNewSize <= MAX_BUFFER_SIZE); ... } 在我们使用C语言.../C++做工程项目时,如果我们能在代码中合理的使用assert,能使我们创建更稳定、质量更好且不易于出错的代码;当需要在一个值为FALSE时中断当前操作的话就可以使用断言。...单元测试必须使用断言;另外除了类型检查和单元测试外,断言还提供了一种确定各种特性是否在程序中得到维护的极好的方法;

    2.3K88

    Go语言日志

    一、日志简介 使用开发工具时,控制台打印的信息就是日志信息 项目最终发布后是没有开发工具的,而需要记录日志应该把信息输出到文件中,这个功能也是日志的功能 在Go语言标准的log包提供了对日志的支持 有三种级别日志输出...Print() 输出日志信息 Panic() 打印日志信息,并触发panic,日志信息为Panic信息 Fatal() 打印日志信息后调用os.Exit(1) 所有日志信息打印时都带有时间,且颜色为红色...std.Output(2, s) panic(s) } 执行后输出日志信息,同时也会触发panic log.Panicln("打印日志信息") 四、致命日志信息 打印日志后,终止程序...os.Exit(1) } 执行日志打印后,程序被终止 log.Fatal("打印日志信息") 五、打印日志信息到文件中 Go语言标准库支持输出日志信息到文件中....Llongfile // full file name and line number: /a/b/c/d.go:23 Lshortfile

    37120

    汇编语言C51C语言C++中左移的不同

    汇编: 1.对于51单片机:RLC A;即将累加器ACC中内容左移1位,最低位被CY原始值替代,最高位移入进位标志CY   中,同理还有RRC A。...具体使用:MOV A,#0FFH; CLR C;   RLC A; 2.对于8086: (1)左移:SHL/SAL DST CNT 移位时操作数的最低位将移入0,最高位移入CF中,若左移若干位,则CF中只保留最后一次移出的内容...C51: 1.在C51中操作符为"中本来的数丢失,最低位补0,其他位依次向左移动1位。右移指令类同。...>>",C语言中的右移运算,一般情况下是高位补零,但在处理有符号数的时候会因计算机系统的不同而不同。...C语言中的左移运算,无论是有符号数还是无符号数都是按照逻辑左移来操作,即向左移动若干位,低位补0即可。

    5.5K100

    嵌入式 C 语言(中)

    在有操作系统的工程中修饰会被多个任务修改的变量 在嵌入式开发中,不仅仅有单片机裸机开发,也有带有操作系统的开发,通常两者使用C语言开发的较多。...enum 用法 enum是C语言中用来修饰枚举类型变量的关键字。...预处理器与预处理指令 本节将简单介绍C语言的预处理器及其预处理指令。...C语言建立在适当的的关键字、表达式、语句以及使用他们的规则上。然而C标准不仅描述C语言,还描述如何执行C预处理器。 C预处理器在执行程序之前查看程序,因而被称之为预处理器。...C语言习惯用.h后缀表示头文件,这些文件包含需要放在程序顶部的信息。头文件经常包含一些预处理指令,有些头文件由系统提供,也可以自定义。

    1.9K20

    C语言基础之【指针】(中)

    往期《C语言基础系列》回顾: 链接: C语言基础之【C语言概述】 C语言基础之【数据类型】(上) C语言基础之【数据类型】(下) C语言基础之【运算符与表达式】 C语言基础之【程序流程结构...】 C语言基础之【数组和字符串】(上) C语言基础之【数组和字符串】(下) C语言基础之【函数】 C语言基础之【指针】(上) 指针和数组 数组名 数组名是一个指向数组首元素的指针常量 ---...在 C 语言中,数组名代表数组首元素的地址,所以这里输出的是数组 a 第一个元素的地址。 printf("&a[0] = %p\n", &a[0]);:输出的是数组 a 第一个元素的地址。...博主正在持续更新C语言基础系列中。 ❤️ 如果你觉得内容还不错,请多多点赞。 ⭐️ 如果你觉得对你有帮助,请多多收藏。...(防止以后找不到了) ‍‍‍ C语言基础系列 持续更新中~,后续分享内容主要涉及 C++全栈开发 的知识,如果你感兴趣请多多关注博主。

    16410

    【C语言】C语言指针超详细攻略:掌握地址的艺术(中)

    前情回顾:C语言指针超详细攻略:掌握地址的艺术(上)_c语言地址指针-CSDN博客 一、数组名的理解 在上一讲的内容中我们在使用指针访问数组的内容时,有这样的代码: int arr[10] = { 1,2,3,4,5,6,7,8,9,10...对于二级指针的运算有: • *ppa通过对ppa中的地址进⾏解引⽤,这样找到的是pa,*ppa其实访问的就是pa....代码如下: #include void test(int(*p)[5], int r, int c) { int i = 0; int j = 0; for (i = 0; i...首字符的地址放到了pstr中。 上面代码的意思是把一个常量字符串的首字符 h 的地址存放到指针变量 pstr 中。...C/C++会把常量字符串存储到单独的一个内存区域,当几个指针指向同一个字符串的时候,他们实际会指向同一块内存。但是用相同的常量字符串去初始化不同的数组的时候就会开辟出不同的内存块。

    14110

    c语言目标程序中的段

    对于一些较为复杂的数学运算如除法(\),取余(%)等,虽然它们是C语言的基本运算,但在各种编译系统中的处理方式却不一定相同。...2.只读数据段(RO Data) 只读数据段由程序中所使用的数据产生,该部分数据的特点是在运行中不需要改变,因此编译器会将该数据放入只读的部分中。C语言的一些语法将生成只读数据段。...在C语言的程序中,对变量的使用还有以下几点需注意: 1.在函数体中定义的变量通常是在栈上,不需要在程序中进行管理,由编译器处理。...程序中段的使用 本小节使用简单的例子,说明C语言中变量和段的对应关系。...C语言源文件中语句如何转换成各个段。

    2.1K30

    C语言 | 统计文章中的字符

    C语言编程实现分别统计出其中英文大写字母、小写字母、数字、空格以及其他字符的个数  解题思路:数组text的行号为0~2,但在提示用户输入各行数据时,小林这里要求读者输入第1行、第2行、第3行,而不是第...为此,在程序第6行中输出行数时用i+1,而不用i。这样并不影响程序对数组的处理,程序其他地方数组的第1个下标值仍然是0~2。 ..."空格 :%d\n",space);   printf("其他字符 :%d\n",other);   return 0;//主函数返回值为0  } 编译运行结果如下: 请随意输入一行: I love C ...以上,如果你看了觉得对你有所帮助,就给小林点个赞,分享给身边的人叭,这样小林也有更新下去的动力,跪谢各位父老乡亲啦~ C语言学习路线    C语言开发工具 C++学习路线 C#学习路线 C语言 | 统计文章中的字符...更多案例可以go公众号:C语言入门到精通

    1.9K64

    C语言范例学习03-中

    采取的是类C的语言。所以需要将其映射为C数据类型。 7 DataType *top; 8 int stacksize; 9 //提醒一句,stack是栈的英文。...其中广义表是线性表的推广,目前多用于人工智能等领域的表处理语言中。所以,有这方面兴趣的可以多多关注。...逻辑: 在一个广义表中,数据元素可以是一个单一元素,也可以是子表,相应地在对应的存储结构中,存储结构节点也有单元素节点和子表节点之分。单元素节点包含值域和指向其后继结点的指针域。...对于子表节点,应包含指向子表中第一个节点的表头指针和指向其后继结点的指针域。...在C++里,union 的成员默认属性页为public。union 主要用来压缩空间。如果一些数据不可能在同一时间同时被用到,则可以使用union。

    24810

    抽丝剥茧C语言(初阶 中)

    C语言初阶(中) 导语 1.字符串+转义字符+注释 字符串 转义字符 注释 2.选择语句 3.循环语句 4.函数 5.数组 数组定义 数组的下标 数组的使用 导语 大家要清楚一件事,C语言有C语言的语法...C语言风格的注释 /xxxxxx/ 缺陷:不能嵌套注释 C++风格的注释 //xxxxxxxx 可以注释一行也可以注释多行 注释通常用来解释你这段代码是干嘛的,让你的代码更能让人读懂,能让你的同事更好的和你合作...C语言也有选择语句,今天先来介绍一种最常用的选择语句,if语句. #include int main() { int coding = 0; printf("你会给骗子汇款吗?...C语言同样也有循环语句: while语句-讲解 for语句(后期讲) do … while语句(后期讲) 让你打印20000次我要继续努力敲代码这句话 你不可能真的一遍一遍的去敲printf(...因为arr可以容纳10个元素,但是只初始化了3个元素,那么系统会默认剩下7个元素为0 这里我们叫做未完全初始化 数组的下标 C语言规定:数组的每个元素都有一个下标,下标是从0开始的。

    1K00
    领券