sprintf_s, strcpy_s等安全函数的第二个长度参数是不是要减1才安全?

如下代码:

char Buff0[256], Buff1[256];
char MyString[256];

// 
sprintf_s(Buff0, 256, "Hello %s", MyString);
strcpy_s(buff1, 256, buff0);
//

疑问:
sprintf_s和strcpy_s的第二个参数是不是改为255最安全,因为有可能256个字符会被全部填满,然后就把\0结束符冲掉了?其他类似的函数是有fgets, recvfrom, strncpy_s, strcat_s等等。

是的,最好这样。字符串申请空间经常有这么写的,#define strlen 1024 char * p = new char[strlen+1];专门增加一个长度

字符数组留一位给'\0',这样保证字符串能够正确结束,所以最好是数组大小-1