函数 snprintf

头文件 #include <stdio.h>

<函数原型>
int snprintf(char *str, size_t size, const char *format, ...)
<函数说明>
最多从源串中拷贝size-1个字符到目标串中,然后再在后面加一个’\0’。所以如果目标串的大小为size的话,将不会溢出。
<参数说明>
char *str:目标数组地址
size_t size:目标数组大小(一般用sizeof()表示)
const char *format:格式化字符串

<推荐的用法>
#include <stdio.h>
#include <stdlib.h>
int main()
{
    char str[10]={0};
    snprintf(str, sizeof(str ) , "0123456789012345678");
    printf("str=%s/n", str);
    return 0;
}
$ ./test
str=012345678
<不推荐使用>
#include <stdio.h>
#include <stdlib.h>
int main()
{
    char str[10]={0};
    snprintf(str, 18, "0123456789012345678");
    printf("str=%s/n", str);
    return 0;
}
$ ./test
str=01234567890123456

发现在Windows版本下面没有snprintf函数,但是在MSDN里发现一个_snprintf 函数,没加注意就在Windows平台下用_snprintf代替了snprintf,突然测试发现有问题,再查看MSDN后才发现_snprintf有 如下的问题。

以下内容转截自 http://blog.csdn.net/youyu_buzai/archive/2008/09/23/2965419.aspx

snprintf(_snprintf)的声明是这样的

int _snprintf(
   char *buffer,
   size_t count,
   const char *format [,
      argument] ...
);

If len < count, then len characters are stored in buffer, a null-terminator is appended, and len is returned.
If len = count, then len characters are stored in buffer, no null-terminator is appended, and len is returned.
If len > count, then count characters are stored in buffer, no null-terminator is appended, and a negative value is returned.

最常见的错误用法有:
1.
char sa[256]={0};
_snprintf(sa,sizeof(sa),"%s",sb);
//错误原因:当sb的长度>=256的时候,sa将没有'/0'结尾

2.
char sa[256];
_snprintf(sa,sizeof(sa)-1,"%s",sb);
//错误原因:当sb的长度>=255的时候,sa将没有'/0'结尾,忘记给sa初始化

3.
char sa[256];
_snprintf(sa,sizeof(sa)-1,"%s",sb);
sa[sizeof(sa)]=0;
//错误原因:最后一行数组越界

正确的用法
1. //推荐用法
char sa[256];
sa[sizeof(sa)-1]=0;
_snprintf(sa,sizeof(sa),"%s",sb);
if(sa[sizeof(sa)-1]!=0)
{
   printf("warning:string will be truncated");
   sa[sizeof(sa)-1]=0;
}

2.
char sa[256]={0};
int result = _snprintf(sa,sizeof(sa),"%s",sb);
if(result==sizeof(sa) || result<0)
{
    printf("warning:sting will be truncated");
   sa[sizeof(sa)-1]=0;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值