关键词

C语言sprintf():将格式化数据输出到数组中

sprintf() 函数是 C语言标准库中的一个非常重要和常用的函数,定义在<stdio.h>头文件中。

sprintf() 函数用于将格式化的输出存储在字符数组中,而不是写入标准输出设备,函数原型如下:
int sprintf(char *buffer,const char *format[,argument...]); 
结合函数原型,sprintf() 函数的功能是将 format 指向的格式化数据输出到 buffer 指向的数组中。

参数

1、buffer

指向用于存储格式化输出的字符数组的指针。

2、format

由格式说明和普通字符构成。其中,普通字符是按照原样输出的字符,如逗号、空格和换行符;格式说明定义 argument 的显示格式,它以”%”开头,后面跟格式字符,格式字符前面还可以有其他修饰符,表示输出数据的宽度、精度等。

参数 format 的格式如下:
%[flags][width][.precision][length]格式字符
格式说明的个数必须与参数 argument 的个数一致。

1) 格式字符及说明如下表所示。
格式字符 说明 示例
d 或 i 带符号十进制整数 26、 285
o 无符号八进制整数 316、 501
x 无符号十六进制整数 8cf、32b7
X 无符号十六进制整数(以大写形式输出) 8CF、32B7
u 无符号十进制整数 1234、 32727
f 小数形式的单、双精度浮点数 102.6、2987.58
e 或 E 指数形式的单、双精度浮点数 1.026e+21.026E+2
g 或 G 以 %f 或 %e 的形式输出浮点数 102.6
c 单个字符 'a'、A
s 字符串 “hello”
p 输出一个指针 0012FF7C

2) flags 控制输出数据的对齐方式,flags 及说明如下表所示。

flags 说明
- 在给定的域宽内靠左端输出
+ 强制在正数前输出 + 号,在负数前输出 - 号
# 使用 o、x 或 X 格式时,在数据前面分别增加前导符 0、0x 或 0X 输出

3) width 控制数据输出的宽度,width 及说明如下表所示。

width 说明
m 输出字段的宽度,如果数据的宽度小于 m,则左端补上空格;否则按照实际位数输出

4) precision 表示单精度和双精度浮点数的小数点个数,precision 及说明如下表所示。

precisi on 说明
n 对于浮点数,表示输出 n 位小数;对于字符串,表示输出字符串的个数

5) length 表示整型数据是长整型还是短整型,length 及说明如下表所示。

length 说明
h 用来输出短整型数据(只对 i、d、0、u、x 和 X 有效)
l 或 L 用来输出长整型数据和双精度型数据

3、argument

表示要格式化输出的数据,分别与格式字符对应。

返回值

调用成功,则返回输出字符的个数(不包括字符串末尾的空字符);否则,返回负数。

实例

以下是一些 C语言 sprintf() 函数的使用示例。
#include <stdio.h>

int main() {
  int age = 30;
  double salary = 50000.50;
  char name[] = "Alice";
  char output[100];

  sprintf(output, "Name: %s, Age: %d, Salary: %.2f", name, age, salary);
 
  printf("%s\n", output); // 输出:Name: Alice, Age: 30, Salary: 50000.50

  return 0;
}
输出结果为:

Name: Alice, Age: 30, Salary: 50000.50

总结

sprintf() 函数提供了一种强大的方式来创建格式化的字符串。它允许精确地控制输出的格式,并可以将输出存储在字符数组中以供后续使用。

需要注意的是,sprintf() 函数存在缓冲区溢出的风险,在适当的情况下可以考虑用更安全的替代品,如 snprintf() 函数。

本文链接:http://task.lmcjl.com/news/15127.html

展开阅读全文