文章转载自:https://blog.csdn.net/varding/article/details/8109440
 
我们在程序里经常需要打印一些字符串来调试或者显示,最简单的方法:
char buff[1024];
sprintf(buff,"%d,%s",i,str);

这样每次都要定义一个buff很麻烦,很容易冲突。于是我们就想到用一个自定义的函数专门格式化这些数据,那么最简单的方法就是用可变参数,简单的列子如下:

//定义
void MyPrint(const char *fmt, ...)
{
 char buff[4096];
 
 va_list args;
 va_start(args, fmt);
 wvsprintf(buff, fmt, args);
 va_end(args);
 
 //buff就是数据了,可以根据需要在这儿保存或者显示
}
//使用方法
MyPrint("%d,%s",i,str);

上面的函数可以将字符串格式化后做统一处理比较方便,如果格式化字符串后用途不同还需要做一些修改:
我们可以对此做一些修改:

//定义
char* MyPrint(const char *fmt, ...)
{
 static char buff[4096];
 
 va_list args;
 va_start(args, fmt);
 wvsprintf(buff, fmt, args);
 va_end(args);
 
 return buff;
 //buff就是数据了
}
//使用
SetDlgItem(IDC_BUTTON1,MyPrint("%d,%s",i,str));
MessageBox(MyPrint("%d,%s",i,str));

因为这儿用了static数组保存格式化后的字符串,因此在下次使用MyPrint的时候确保上次的结果已经不再需要了
下面是添加了时间信息的log记录函数:

void WriteLog(const char *fmt, ...)
{
 SYSTEMTIME sysTime;
 GetLocalTime(&sysTime);
 
 char szBuffer[4096];
 DWORD dwSize = wsprintf(szBuffer, "[%02d:%02d:%02d] ", sysTime.wHour, sysTime.wMinute, sysTime.wSecond);
 
 va_list args;
 va_start(args, fmt);
 dwSize += wvsprintf(szBuffer + dwSize, fmt, args);
 va_end(args);
 
 lstrcpy(szBuffer + dwSize, "\r\n");
 dwSize += 2;
 //记录函数
}
 

自定义printf 打印函数的更多相关文章

  1. stm32_f103使用gcc编译的环境下printf打印函数的实现

    前记   gcc编译使用的printf打印函数需要的底层函数是和其他编译器不同的,以前的是无法使用的,这里有两种方法,一种是使用gcc库里面的printf函数,自己实现底层IO函数_write.另外一 ...

  2. Objective-C与Swift下的自定义打印函数(Debug和Release)

    1.Objective-C 在使用Objective-C进行开发的过程中,为了Debug会不断的设置打印函数.如下图是我们经常用的,用来测试监听方法的实现与否: NSLog(@"%s&quo ...

  3. 嵌入式操作系统---打印函数(printf/sprintf)的实现

    一.打印函数简介 作用:将“给定的内容”按照“指定的格式”输出到“指定目标内”. 打印函数的基本格式: char print_buf[BUF_SIZE]; void printf(const char ...

  4. .net开发---自定义页面打印区域

    自定义页面打印区域 有3种办法: 办法一:将不需要打印的部位隐藏掉 Examp: <%-- (1)使用css样式,定义一个.noprint的class,将不打印的内容放入这个class内. -- ...

  5. C程序中引用自定义的C函数模块

    原文:C程序中引用自定义的C函数模块 我们知道,刚开始接触C语言编程,一般都是在一个.c或者.cpp(以下只说.c)的文件中编写代码,其中一定会有一个入口函数, 也就是main()函数,你可以将程序代 ...

  6. 小程序重新封装打印函数console.log

    习惯性使用console.log打印获取到的数据,信息等,然后上星期大佬看见了说怎么那么多打印信息出来,线上那个也是吗?问我能不能线上的就不打印出来? 我就说那就封装一个打印函数呗. 重写一个没问题, ...

  7. yii学习笔记(3),自定义全局工具函数

    在平时开发是经常需要打印数据来调试 常见的打印方式有print_r和var_dump,但是这样打印出来格式很乱不好浏览 在打印函数前后加上<pre></pre>就可以将内容原样 ...

  8. 自定义JS Map 函数

    // 自定义JS Map 函数 function Map() { var map = function (key, value) {//键值对 this.key = key; this.value = ...

  9. Visual Studio C++ MFC界面常用参数更改(改变图标,添加控件,调试打印函数等等)

    背景 需要使用Visual Studio C++做一些界面.此篇文章既是记录Visual Studio C++在调整界面时常常遇见的问题. 正文 一.如何更改窗体图标,以及生成的.exe图标 更改窗体 ...

随机推荐

  1. java的mock工具:mockito

    https://site.mockito.org https://github.com/mockito/mockito https://github.com/hehonghui/mockito-doc ...

  2. C语言 班级档案管理系统实现

    代码地址:github地址 班级档案管理系统 原题目要求是对一个有N个学生的班级,通过该系统实现对该班级学生的基本信息进行录入. 显示.修改.删除.保存等操作的管理. 由于个人需要,我单独将项目改造为 ...

  3. JavaScript中的Truthy和Falsy

    JavaScript中存在Truthy值和Falsy值的概念 — 除了boolean值true.false外,所有类型的JavaScript值均可用于逻辑判断,其规则如下: 1.所有的Falsy值,当 ...

  4. 学习JavaScript之this,call,apply(转)

    转自: http://www.h5cn.com/js/jishu/2016/0128/17884.html 在之前的JavaScript学习中,this,call,apply总是让我感到迷惑,但是他们 ...

  5. 第一周——不同java 的发展史你,注定成为不了领袖型人才

     James Gosling  1991年,James 高斯林在Sun公司的工程师小组想要设计这样一种小型计算机语言,该语言主要用于电视盒的消费类电子产品上.另外,由于不同的厂商选择不同的CPU和操作 ...

  6. order pick-up and delivery problem

    问题一: pi表示取第i个单,di表示送第i个单.di不能在pi的前面.给一个取单送单的顺序,问是否是valid顺序. public boolean isValidOrderList(List< ...

  7. superset的安装(win10)踩踩坑!AWSL

    基本安装参考https://www.jianshu.com/p/8b27ff71429f 按此方案装的时候会遇到各种flask版本不兼容的问题,所以 第一步:装好anaconda 第二部:保证好高于V ...

  8. Java 最常见 200+ 面试题 + 全解析

    本文分为十九个模块,分别是: Java 基础.容器.多线程.反射.对象拷贝.Java Web .异常.网络.设计模式.Spring/Spring MVC.Spring Boot/Spring Clou ...

  9. (九)Javabean与Jsp(来自那些年的笔记)

    目录 JavaBean 在JSP中使用JavaBean 标签用法 带标签体的 JavaBean 标签 setProperty 标签 getProperty 标签 JSP开发模式 案列:使用 模式一 编 ...

  10. Spring Boot系列教程十二:Spring boot集成Redis

    一.创建项目 项目名称为 "springboot_redis",创建过程中勾选 "Web","Redis",第一次创建Maven需要下载依赖 ...