首先分析一下:这四个函数观察其尾部,有_s,和无_s;其中有_s的是有安全校验的,如果函数参数错误会报错。(vs2012)
1.sprintf(char* _Dest, const char* Format……);
但是在应用的时候一般这样:
char* str = "wanggnaw";
char buf[5] = {0};
sprintf(buf,"%s",str);
当输出buf时,会直接输出wanggnaw,但是很明显,此时的输出已经超过了buf应有的长度,发生了越界。而且这个操作系统不会报错。所以有了更为安全的,带有安全校验的sprintf_s
2.sprintf_s(char* Dest, size_t SizeInBytes, char* Format……);
char* str = "wanggnaw";
char buf[5] = {0};
sprintf_s(buf,"%s",str);
这个时候编译器会报错,此时buf只能放五个元素,所以只有当str的元素小于等于五个元素时,才可以正常操作。
3._snprintf(char* Dest, size_t _Count, char* Format……);
char* str = "wanggnaw";
char buf[5] = {0};
_sprintf(buf,sizeof(buf)-1,"%s",str);
解释一下:就是将向buf里写,写buf这么大,以“%s”的格式,从str里拿。这里有考究的时第二个参数:首先是获得buf大小只能是用sizeof,因为此时strlen(buf)里面是空的;再一个,如果用sizeof,也就是将buf全写满了,当输出时,尾部会有乱码,因为找不到'\0',所以一直找,期间就有乱码,所以这里应该时sizeof(buf)-1,把最后一位空出来,因为之前使用buf时不是赋值为 0 了吗。所以说,如果书写正确,应该是 sizeof(buf)-1.
4._snprintf_s(char* Dest, size_t Count, char* Format……);
这个函数和 3._snprintf 注意的事项相同,区别在于,如果第二个参数超过了 sizeof(buf)-1,编译器会报错。