sprintf函数的用法

1、该函数包含在stdio.h的头文件中。
2、sprintf和平时我们常用的printf函数的功能很相似。sprintf函数打印到字符串中(要注意字符串的长度要足够容纳打印的内容,否则会出现内存溢出),而printf函数打印输出到屏幕上。sprintf函数在我们完成其他数据类型转换成字符串类型的操作中应用广泛。
3、sprintf函数的格式:
int sprintf( char *buffer, const char *format [, argument,…] );
除了前两个参数固定外,可选参数可以是任意个。buffer是字符数组名;format是格式化字符串(像:”%3d%6.2f%#x%o”,%与#合用时,自动在十六进制数前面加上0x)。只要在printf中可以使用的格式化字符串,在sprintf都可以使用。其中的格式化字符串是此函数的精华。
printf 和sprintf都使用格式化字符串来指定串的格式,在格式串内部使用一些以”%”开头的格式说明符来占据一个位置,在后边的变参列表中提供相应的变量,最终函数就会用相应位置的变量来替代那个说明符,产生一个调用者想要的字符串。
4、可以控制精度
char str[20];
double f=14.309948;
sprintf(str,”%6.2f”,f);
5、可以将多个数值数据连接起来
char str[20];
int a=20984,b=48090;
sprintf(str,”%3d%6d”,a,b);
str[]=”20984 48090”
6、可以将多个字符串连接成字符串
char str[20];
char s1[5]={‘A’,’B’,’C’};
char s2[5]={‘T’,’Y’,’x’};
sprintf(str,”%.3s%.3s”,s1,s2);
%m.n在字符串的输出中,m表示宽度,字符串共占的列数;n表示实际的字符数。%m.n在浮点数中,m也表示宽度;n表示小数的位数。
7、可以动态指定,需要截取的字符数
char str[20];
char s1[5]={‘A’,’B’,’C’};
char s2[5]={‘T’,’Y’,’x’};
sprintf(str,”%.*s%.*s”,2,s1,3,s2);
sprintf(str, “%*.*f”, 10, 2, 3.1415926);
8、可以打印出i的地址
char str[20];
int i;
sprintf(str, “%p”, &i);
上面的语句相当于
sprintf(str, “%0*x”, 2 * sizeof(void *), &i);
9、sprintf的返回值是字符数组中字符的个数,即字符串的长度,不用在调用strlen(str)求字符串的长度。
10、使用字符指针指向的字符串来接收打印的内容
例子:

int main()
{int ddd=666;char *buffer=NULL;    if((buffer = (char *)malloc(80*sizeof(char)))==NULL){printf("malloc error\n");}sprintf(buffer, "The value of ddd = %d", ddd);//The value of ddd = 666printf("%s\n",buffer);free(buffer);buffer=NULL;return 0;
}

指针刚开始定义的时候,并不指向所处,可以指向一个变量,然后可以用,如果要单纯用这个指针,那么要给这个指针malloc分配一片内存,加了malloc就要加stdlib.h
11、设想当你从数据库中取出一条记录,然后希望把他们的各个字段按照某种规则连接成一个字符串时,就可以使用这种方法,从理论上讲,他应该比strcat 效率高,因为strcat 每次调用都需要先找到最后的那个字符串结束字符’\0的位置,而在上面给出的例子中,我们每次都利用sprintf 返回值把这个位置直接记下来了。
例子:

void main(void)
{ char buffer[200], s[] = "computer", c = 'l'; int i = 35, j; float fp = 1.7320534f; // j = sprintf( buffer, " String: %s\n", s ); // j += sprintf( buffer + j, " Character: %c\n", c ); // j += sprintf( buffer + j, " Integer: %d\n", i ); // j += sprintf( buffer + j, " Real: %f\n", fp );// printf( "Output:\n%s\ncharacter count = %d\n", buffer, j );
}

该例子是将所有定义的数据和格式控制块中的字符连接在一起,最后打印出来buffer的内容和字符串中字符的个数。
结果如图所示:

12、 格式化数字字符串
sprintf最常见的应用之一莫过于把整数打印到字符串中。如:
(1)把整数123打印成一个字符串保存在s中。
sprintf(s, “%d”, 123); //产生“123″
(2)可以指定宽度,不足的左边补空格:
sprintf(s, “%8d%8d”, 123, 4567); //产生:“ 123 4567″
当然也可以左对齐:
sprintf(s, “%-8d%8d”, 123, 4567); //产生:“123 4567″
(3)也可以按照16进制打印:
sprintf(s, “%8x”, 4567); //小写16进制,宽度占8个位置,右对齐
sprintf(s, “%-8X”, 4568); //大写16进制,宽度占8个位置,左对齐
这样,一个整数的16进制字符串就很容易得到,但我们在打印16进制内容时,通常想要一种左边补0的等宽格式,那该怎么做呢?很简单,在表示宽度的数字前面加个0就可以了。
sprintf(s, “%08X”, 4567); //产生:“000011D7″
上面以”%d”进行的10进制打印同样也可以使用这种左边补0的方式。
这里要注意一个符号扩展的问题:比如,假如我们想打印短整数
(4)(short)-1的内存16进制表示形式,在Win32平台上,一个 short型占2个字节,所以我们自然希望用4个16进制数字来打印它:
short si = -1;
sprintf(s, “%04X”, si);
产生“FFFFFFFF,怎么回事?因为 sprintf是个变参函数,除了前面两个参数之外,后面的参数都不是类型安全的,函数更没有办法仅仅通过一个“%X”就能得知当初函数调用前参数压栈时 被压进来的到底是个4字节的整数还是个2字节的短整数,所以采取了统一4字节的处理方式,导致参数压栈时做了符号扩展,扩展成了32位的整数-1,打印时 4个位置不够了,就把32位整数-1的8位16进制都打印出来了。如果你想看si的本来面目,那么就应该让编译器做0扩展而不是符号扩展(扩展时二进制左边补0而不是补符号位):
sprintf(s, “%04X”, (unsigned short)si);
就可以了。或者:
unsigned short si = -1;
sprintf(s, “%04X”, si);
sprintf和printf还可以按8进制打印整数字符串,使用”%o”。注意8进制和16进制都不会打印出负数,都是无符号的,实际上也就是变量的内部编码的直接用16进制或8进制表示。

参考:http://blog.csdn.net/cos_sin_tan/article/details/7548632
http://nnssll.blog.51cto.com/902724/198237/
http://blog.csdn.net/s202090414/article/details/8690518
http://blog.csdn.net/peng___peng/article/details/51510685

C语言中sprintf()函数的用法相关推荐

  1. C语言中atoi()函数的用法

    C语言中atoi()函数的用法 一.学习要点: 1.int atoi(const char *str)把参数str所指向的字符串转换为一个整数: 二.代码 #include<stdio.h> ...

  2. c语言memcopy_C语言中memcpy 函数的用法详解

    C语言中memcpy 函数的用法详解 memcpy(内存拷贝函数) c和c++使用的内存拷贝函数,memcpy函数的功能是从源src所指的内存地址的起始位置开始拷贝n个字节到目标dest所指的内存地址 ...

  3. c语言中sprintf函数_在C / C ++中使用sprintf()函数

    c语言中sprintf函数 In this article, we'll take a look at using the sprintf() function in C / C++. 在本文中,我们 ...

  4. C语言中fscanf()函数的用法介绍

    C语言中fscanf()函数的用法介绍 fscan()函数的原型: int fscanf(FILE *stream,const char *format,[argument...]); fscanf函 ...

  5. c语言time函数的作用,c语言中time函数的用法

    c语言中time函数的用法 c语言中time函数的用法的用法你知道吗?下面应届毕业生小编就跟你们详细介绍下c语言中time函数的用法的用法,希望对你们有用. c语言中time函数的用法的用法如下: 头 ...

  6. c语言中fputc函数的作用是,C语言中fputc函数的用法

    C语言中fputc函数的用法 C语言中fputc函数的用法为"int fgetc (FILE *fp)",该函数的作用是从指定的文件中读取一个字符, 读取成功时会返回读取到的字符, ...

  7. c语言中fputc函数的作用是,C语言中fputc函数的用法_后端开发

    Python画ROC曲线和AUC值计算(附代码)_后端开发 ROC(Receiver Operating Characteristic)曲线和AUC常被用来评价一个二值分类器的优劣.这篇文章将先简单的 ...

  8. 关于C语言中getchar()函数的用法

    前言:ASCII码 ASCII码是现在通用的单字节编码系统,它使用7位或8位二进制数字的指定组合来表示128或256个可能的字符,其全称是美国信息交换标准代码.ASCII码对照表:ascii码对照表在 ...

  9. c语言中sizeof函数的用法,sizeof函数怎么用 sizeof函数的使用方法

    sizeof函数是pascal语言当中的一种内存容量度量的函数,这一个函数计算得到的结果是返回一个变量或者一个类型的大小;在c语言当中,sizeof函数这是一个能够判断数据类型,或者是表达式长度的一个 ...

  10. c语言中sizeof函数的作用是,c语言中sizeof函数的用法

    C语言sizeof函数如何使用? 怎样利用sizeofCSS布局HTML小编今天和大家分享各种数据类型占用的字节数? (1)sizeof不是函数,它只是一个操作符(operator). (2)size ...

最新文章

  1. python2.7不换行输出_python输出不换行
  2. map和reduce
  3. 设计人员珍藏的在线处理图片的网址大集合
  4. 【今日CS 视觉论文速览】 24 Dec 2018
  5. VLAN TAG 实例
  6. StringUtils一些常用方法
  7. WPF中DataGrid的使用实例
  8. 最小化安装CentOS 7后,图形界面的安装(GNOME、KDE等)
  9. python学习之路——day1(18/9/11)
  10. UVAlive3662 Another Minimum Spanning Tree 莫队算法
  11. UITextFiled 简介
  12. RuntimeError: Exporting the operator affine_grid_generator to ONNX opset version 9 is not supported.
  13. Blender烘焙光照贴图
  14. postfix 安装
  15. 安卓玩机搞机技巧综合资源-----修改rom 制作rom 解包rom的一些问题解析【二十一】
  16. 简述Android操作系统和IOS系统的区别;
  17. 惯性导航原理(1):导航坐标系及相互转换
  18. 阿里云购买免费ssl证书
  19. SQL Server 2016 [修改数据库名称]及[添加次文件和日志文件]
  20. Camtasia视频剪辑功能详解

热门文章

  1. Chango的数学Shader世界(十八)RayTrace三维分形(三)—— 完善,距离场软阴影
  2. 混合云架构下的安全风险分析和安全解决方案建议
  3. final 类和不可变类
  4. dll注入之SetWindowsHookEx 键盘消息钩子
  5. Ubuntu操作系统的学习,从新手到老手的过渡
  6. Android MeasureSpec详解
  7. 身份证阅读器在人事管理中的運用
  8. 新欢乐时光病毒程序源码分析
  9. Github使用: 无法打开github网页
  10. 百度搜索无法显示搜索结果