C语言_格式化输入输出

Ustinain 等级 737 1 1

C语言_格式化输入输出

我们知道在最开始输入输出的printf和scanf里可以用百分号跟上一个字母d 说明要整数的类型,%f说明要以浮点数输出

  • printf()

  • %[flags][width][.prec][hlL]type

  • scanf()

  • %[flag]type

    我们知道在最开始输入输出的printf和scanf里可以用百分号跟上一个字母d 说明要整数的类型,%f说明要以浮点数输出,殊不知这其中还有很多数值....

  • %[flags][width][.prec][hlL]type

type 含义
- 左对齐
+ 在前面放+或-
(space) 正数留空
0 0填充
我们来试一下这样的事情,如下 做一个简单的模型
    printf("%9d\n",123);
    printf("%-9d\n",123);

第一个%9d表示后面数字的输出占据九个字符的空间,并且是右对齐的,所以前面留出来空格 而第二个带-号表示是左对齐

"+" 号含义是后面要跟上+号或者- 号,我们试试

  printf("%+9d\n",123);
  printf("%+-9d\n",123);

运行结果: C语言_格式化输入输出 果不其然 ,前面加上了+号

printf("%+9d\n",-123);
printf("%+-9d\n",-123);

运行结果: C语言_格式化输入输出 这样都没什么问题 其实如果不要第二行这个+ 号,编译器也同样会加上-号的,那么我们加0呢

printf("%09d\n",123);
printf("%0-9d\n",-123);

运行结果: C语言_格式化输入输出 可以看到右对齐的前面补了零,而左对齐的-123是不能补零的,总不能向后填零吧 |width或prec | 含义 | |--|--| | number |最小字符数| ||下一个参数是字符数| |.number|小数点后的位数| |.|下一个参数是小数点后的位数

printf("%9.2f\n",123.0);

运行结果: C语言_格式化输入输出 这里注意一下, 小数点前面的9指的是整个数字包括小数点以及小数点后面的0,总和占9个字符 而不是小数点前面占9个字符,.2f 表示精确到小数点后俩位 那么那个*又是表达什么意思呢

printf("%*d\n",5,123);
printf("%9.2f\n",123.0);

运行结果: C语言_格式化输入输出 可以看到第一行后面的形参多了一个,就好比把5 这个值替换了*,而后面的123是用来满足这个%d的,原本要填入%后面的数字,现在可以替换出来,而一旦变成后面的参数,那他就可以是一个变量了,而不是常量,给我们的代码格式带来了很大的灵活性

类型修饰 含义
hh 单个字节
h short
l long
ll long long
L long double
type 作用
i或d int
u unsigned int
a或A 十进制浮点数
0 八进制
c char
x 十六进制
s 字符串
X 字母大写的十六进制
p 指针
f或F float
n 读写/写入的个数
e或E 指数
暂时列出来,有些学到后面会慢慢遇见 ,不过这里要讲一下n这个type
int num;
printf("%dsos%n\n",12345,&num);

运行结果: C语言_格式化输入输出 字符串后面的第一个参数12345,满足了%d,后面的sos也输出了, %n说明符输出有效字符数量,然后把个数传入后面的指针里。

  • scanf
  • %[flag]tpye
flag 含义
* 跳过
数字 最大字符数
hh char
h short
l long ldouble
ll long long
L long double

有一点我们需要注意,我们要确保转换说明的数量、类型、和后面的参数的数量、类型一样,例如下面的语句中有俩个%d转换说明,说明后面还有俩个参数

printf("%d 个苹果 %d 元\n",number,money);

后面的确有俩个参数 用来满足俩个%d转换说明 现在C语言通过函数原型机制检查函数调用时参数的个书和类型是否正确,但是这对printf()和scanf()函数不起作用,原因是因为这个俩个函数的参数个数可变,如下:

int a=4;
int b=6;
float x=3.14f;   
float y=8.0f;
printf("%d\n",a,b);   //参数过多
printf("%d %d\n",a);  //参数过少
printf("%d %d\n",x,y); //转换说明类型不匹配

运行结果: C语言_格式化输入输出 用%d显示float类型的值,这个值不会被转成int类型,在不同的平台下面,运行结果也会导致不同

注意:通常3.14和8.0都会被编译器存储在64位的double类型中,使用双精度进行乘法运算,然后将乘积截断成float的快读,这样虽然计算精度更高,但无疑会减慢运行速度,我们不是在做非常精确的计算 ,所以不用那么精准,可以在浮点数后面加上F或f后缀就可以覆盖编译器默认的是指,编译器会将浮点类型常量看作float类型 ** 没有后缀的浮点常量是double类型。** 很显然这都不是我们想要的结果,所有的编译器都能编译并且运行这个程序,但是大部分的编译器都会给予警告,的确,有些编译器会捕捉到这类问题,但是c标准没有对此多要求,所以,计算机在运行时可能不会捕捉到这类错误,如果程序正常运行,很难察觉出来,大概只有程序没有打印出你所期望的或者意想不到的值的时候,你才会去检查prinf()函数中的参数类型和个数是否正确

收藏
评论区

相关推荐

C++概述
概述 C 是静态,可编译,通用,大小写敏感,格式自由的编程语言,它支持程序化,面向对象的,和泛型编程方式。 C 被看作是中间层语言,因为它同时包含了低级语言和高级语言的特性。 C 是于 1979 年在新泽西的茉莉山丘的贝尔实验室由 Bjarne Stroustrup 开发的,它是 C 语言的加强版,最开始它被称作 “C with Classes”,但是
C语言_格式化输入输出
C语言_格式化输入输出 我们知道在最开始输入输出的printf和scanf里可以用百分号跟上一个字母d 说明要整数的类型,%f说明要以浮点数输出 printf() %flagswidth.prechlLty
C语言基础习题50例(二)6-10
给大家推荐一门大数据Spark入门课程,希望大家喜欢。 习题6 用 号输出字母C的图案。实现思路:单行打印即可。代码如下:cinclude <stdio.h int main (void){ printf("\n"); printf("\n"); printf("\n"); printf("
C语言中指针及其应用高级篇(用指针实现数组的扩增)
一、一级指针与一维数组把指针充当变量的用法,在C/C++的数据结构学习中广为应用,这种用法学习起来是比较简单的。先看代码。这里的代码,有string.h头文件包含的函数,和scanf,这两者在正常的写法中不用加“s”,这篇随笔所及代码的运行环境是Visual Studio2017,编译器会把scanf等函数增强,因此为了正常运行,会加上“s”.cdefine
计算(变量)
include <stdio.hint main() int price 0; printf ("请输入金额(元)"); scanf ("%d",&price); int change 100 price; printf ("找您%d元\n",change); return 0;上述程序编译执行的结果如下: $ cp
题解5道c++面试题第一期(含解题思路、答案解析和实现代码)
本篇文章送上5道c/c++面试题目,并附上答案、解题思路以及扩展知识。 1. 求下面函数的返回值c++include <stdio.hint func(int x) int iCnt 0; while(x) iCnt++; x x&(x1); return iCnt;int main() printf("cnt %d\n", func(9999
2.8 C++输入与输出
点击上方“C语言入门到精通”,选择置顶 第一时间关注程序猿身边的故事 ![](https://oscimg.oschina.net/oscnet/2b704b60-86f1-49e3-ba49-33f97808128b.png) 作者 闫小林 白天搬砖,晚上做梦。我有故事,你有酒么? **C++输入输出介绍**
2.C++中的bool类型,三目运算符,引用
本章主要内容: * **1)**bool类型 * **2)**三目运算符 * **3)**引用 * * * **1.布尔型bool** 在C++中,bool类型只有true**(****非0)**和flase**(0)**两个值,且bool类型只占用了一个字节. 例如: #include <stdio.h>
C++如何输入含空格的字符串
1、scanf函数(包含头文件#include <stdio.h>)    scanf函数一般格式为scanf(“%s”,st),但scanf默认回车和空格是输入不同组之间的间隔和结束符号,所以输入带空格,tab或者回车的字符串是不可以的。解决方法如下: 1)利用格式符“%\[\]”它的作用为扫描字符集合。Scanf(“%\[^c\]”,str); 其中“
C-C++对于字符串输入处理
**1、scanf** **![](https://oscimg.oschina.net/oscnet/8846482c8872d698586c01e1f6cf854a364.png)** scanf以%s格式符读入字符串,会以空格为结束,也就是无法将空格读入。如果换成%c就可以读入,但是无法一次性读入一整行字符。 **2、fgets** **![]
C语言使用信号量机制实例:
C语言使用信号量机制实例: #include <signal.h> #include <unistd.h> #include <stdio.h> #include <sys/types.h> void sigroutine(int signo){ switch(signo){
Java【NIO2】- 系列 1: 为什么要写【NIO2】系列?
1\.   基本 概念 IO 是主存和外部设备 ( 硬盘、终端和网络等 ) 拷贝数据的过程。 IO 是操作系统的底层功能实现,底层通过 I/O 指令进行完成。 所有语言运行时系统提供执行 I/O 较高级别的工具。 (c 的 printf scanf,java 的面向对象封装 ) 2\.    Java 标准 io 回顾 Java 标准
3 汇编的函数调用
3 汇编的函数调用 ========= 3.1 无参数和返回值的函数调用 ---------------- **void** **func\_void**() { printf("func, no param, no return value\\n"); } // func\_void(); asm ("call func\_void"); //
C++ Modern C++
        现代的C++,比较笼统。最近10多年的东西是否是现代的呢?我认为“时髦”这个词更准确一些。每个年代,时髦总是标新立异的,总是被年龄大一些的人看不惯的(虽然这些人也曾经“赶过时髦”)。Modern C++就是用最时髦的东西去装饰您的代码。但是本质的东西还是没有变。改革初期,最时髦的服饰是喇叭裤,霹雳舞手套。那时没有智能手机,时髦的人扛着一台卡带
Go语言fmt.Printf使用指南
Go语言fmt.Printf使用指南 ================== fmt标准库是我们在学习Go语言过程中接触最早最频繁的一个了,本文介绍了fmtb包的一些常用函数。 fmt === fmt包实现了类似C语言printf和scanf的格式化I/O。主要分为向外输出内容和获取输入内容两大部分。 向外输出 ---- 标准库`fmt`提供了以下几