C语言 sprintf函数使用详解

srpintf()函数的功能非常强大:效率比一些字符串操作函数要高;而且更具灵活性;可以将想要的结果输出到指定的字符串中,也可作为缓冲区,而printf只能输出到命令行上~

头文件:stdio.h

函数功能:格式化字符串,将格式化的数据写入字符串中。

函数原型:int sprintf(char *buffer, const char *format, [argument]...)

参数:

(1)buffer:是char类型的指针,指向写入的字符串指针;

(2)format:格式化字符串,即在程序中想要的格式;

(3)argument:可选参数,可以为任意类型的数据;

函数返回值:buffer指向的字符串的长度;

用处:

(1)格式化数字字符串:在这点上sprintf和printf的用法一样,只是打印到的位置不同而已,前者打印给buffer字符串,后者打印给标准输出,所以sprintf也可以用来将整型转化为字符串,比itoa效率高且如此地简便~比如:sprintf(buffer, "%d", 123456);执行后buffer即指向字符串“123456”~

(2)连接字符:

下面通过两个例子来说明这个问题:

(a)连接以'\0'结束的字符串:

#include<stdio.h>  
int main()  
{  
    char buffer[10];  
    char *a = "1234";  
    char *b = "5678";  
    sprintf(buffer, "%s%s", a, b);  
    printf("%s\n", buffer);  
    return 0;  
} 

结果是12345678。

(b)连接结尾没有'\0'的字符数组或字符串缓冲区:

include<stdio.h>
int main()
{
	char a[] = {'1', '2', '3', '4'};
	char b[] = {'5', '6', '7', '8'};
	char buffer[10];
	sprintf(buffer, "%.4s%.4s", a, b);
	printf("%s\n", buffer);
	return 0;
}

结果是12345678.

(c)如果我们想动态获取要处理的字符缓冲区长度,则将上面sprintf改为:sprintf(buffer, "%.*s%.*s", sizeof(a), a, sizeof(b), b);即可~

(3)利用sprintf中的返回值

因为sprintf函数的返回值为output+pos所指向字符串的长度,所以对于pos来说,相当于执行了一次pos+=sizeof(output+pos),如果这条语句放在一个循环里,则第二次执行sprintf时output+pos随即指向了当前缓冲区的末尾(注意不是output的末尾!否则会读取非法内存!),这样就可以生成一个具有一定规则的字符串了~写个例子:

    #include<stdio.h>
    int main()
    {
    	char buf[100];
    	int pos = 0;
    	for(int j = 0; j < 10; j++)
    		pos += sprintf(buf+pos, "%d-", j);
    	buf[pos-1] = '\n';//将最后一个字符'-'转换为'\n'
    	printf(buf);
    	return 0;
    }

pos每次增加2,因为每次buf字符串后面都要加上两个字符j和‘-’。结果如下

猜你喜欢

转载自blog.csdn.net/rocky_56X/article/details/81186255