当前位置: 首页 > news >正文

printf

printf() 是 C 和 C++ 标准库中的一个输出函数,位于 <cstdio> 头文件中。下面为你详细介绍它的相关知识点。

1. 基本使用

printf() 函数的作用是按照指定格式将数据输出到标准输出设备(通常是控制台)。其基本语法如下:

cpp

#include <cstdio>

int main() {
    int num = 42;
    printf("The number is %d\n", num);
    return 0;
}

在这个例子中,printf() 函数的第一个参数是格式字符串 "The number is %d\n",其中 %d 是格式说明符,代表要输出一个十进制整数,\n 是换行符。第二个参数 num 是要输出的具体数据。

2. 格式说明符

printf() 支持多种格式说明符,用于指定不同类型的数据输出格式,常见的格式说明符如下:

格式说明符描述
%d 或 %i输出十进制整数
%u输出无符号十进制整数
%f输出浮点数
%c输出单个字符
%s输出字符串
%p输出指针地址
%x 或 %X输出十六进制整数(%x 输出小写字母,%X 输出大写字母)

示例代码:

cpp

#include <cstdio>

int main() {
    int num = 10;
    unsigned int unsigned_num = 20;
    float float_num = 3.14;
    char ch = 'A';
    const char* str = "Hello";

    printf("Decimal: %d\n", num);
    printf("Unsigned decimal: %u\n", unsigned_num);
    printf("Float: %f\n", float_num);
    printf("Character: %c\n", ch);
    printf("String: %s\n", str);

    return 0;
}

3. 格式控制

你可以通过格式说明符来控制输出的宽度、精度等。

  • 宽度控制:在格式说明符中可以指定输出的最小宽度。

cpp

#include <cstdio>

int main() {
    int num = 123;
    printf("Width 5: %5d\n", num); // 输出宽度为 5,不足部分用空格填充
    return 0;
}

  • 精度控制:对于浮点数,可以使用 . 后面跟数字来指定小数部分的精度。

cpp

#include <cstdio>

int main() {
    float num = 3.14159;
    printf("Precision 2: %.2f\n", num); // 输出保留两位小数
    return 0;
}

4. 返回值

printf() 函数会返回成功输出的字符数(不包括字符串结束符 '\0')。如果发生错误,则返回一个负数。

cpp

#include <cstdio>

int main() {
    int result = printf("Hello, World!\n");
    printf("Number of characters printed: %d\n", result);
    return 0;
}

5. 注意事项

  • 参数匹配printf() 函数要求格式说明符和实际参数的类型及数量要匹配,否则可能会导致未定义行为。

cpp

#include <cstdio>

int main() {
    int num = 10;
    // 错误示例:格式说明符和参数类型不匹配
    // printf("The number is %f\n", num); 
    return 0;
}

  • 缓冲区问题printf() 输出是行缓冲的,即遇到换行符 \n 或者缓冲区满时才会真正输出内容。你可以使用 fflush(stdout) 来强制刷新缓冲区。

cpp

#include <cstdio>

int main() {
    printf("This will be printed immediately.");
    fflush(stdout);
    return 0;
}

以上就是 printf() 函数的主要知识点,通过合理运用这些知识,你能实现灵活多样的输出需求。

分享

在printf函数中,怎么输出布尔值?

除了printf,C++还有哪些输出函数?

如何在printf函数中控制输出的宽度和精度?

http://www.dtcms.com/a/122984.html

相关文章:

  • 【NLP 面经 9、逐层分解Transformer】
  • 第十一章 Python语言-高阶技巧(终章)
  • Dubbo(44)如何排查Dubbo的服务依赖问题?
  • 17. git pull
  • 6、nRF52xx蓝牙学习(nrf_gpiote.c库函数学习)
  • 基于 AI智能体、大模型、RAG、Agent 等技术构建公司内部闭环智能问答系统的详细方案,结合 Spring Boot + Vue 管理系统 的改造思路
  • Http代理服务器选型与搭建
  • Starrocks的Bitmap索引和Bloom filter索引以及全局字典
  • 基于微信小程序的志愿服务系统的设计与实现
  • 数字图像处理作业3
  • fuse-python使用fuse来挂载fs
  • 汽车软件开发常用的建模工具汇总
  • Joomla 常用模块 - 在线用户与Joomla 常用模块 - 自定义HTML模块
  • [leetcode]判断质数
  • 关于C++日志库spdlog
  • JS 函数提升
  • 蓝桥杯十一届C++B组真题题解
  • 革新电销流程,数企云外呼开启便捷 “直通车”
  • 各种场景的ARP攻击描述笔记(超详细)
  • stream流Collectors.toMap(),key值重复问题
  • Bootstrap Table动态修改列标题
  • C++中命名空间namespace|头文件h文件|源文件cpp文件详解
  • pyecharts常用图形
  • Mysql索引(二)
  • 8.第二阶段x64游戏实战-string类
  • UE学习记录part15
  • ffpyplayer+Qt,制作一个视频播放器
  • 玩转Docker | 使用Docker安装FileDrop文件共享工具
  • 如何解【决泛型作为运行时参数】时类型擦除问题
  • PowerBI数据建模2:计算选项、计算组