我正在尝试创建一个sscanf
字符串文字,以帮助在C99中防止缓冲区溢出。目标是这样的:
#define MAX_ARG_LEN 16
char arg[MAX_ARG_LEN] = "";
if (sscanf(arg, "%"(MAX_ARG_LEN-1)"X", &input) > 0)
显而易见的“手动”解决方案如下:
#define MAX_ARG_LEN 16
#define MAX_ARG_CHARS "15"
char arg[MAX_ARG_LEN] = "";
if (sscanf(arg, "%"MAX_ARG_CHARS"X", &input) > 0)
但是,我希望在缓冲区大小为16的情况下自动生成“%15X”。此链接几乎适用于我的应用程序:Convert a preprocessor token to a string但它不处理-1
连连呢?
答案 0 :(得分:7)
Kernighan和Pike在他们的(优秀)书籍“The Practice of Programming”中讨论了这个问题,并得出结论,最可靠和最便携的方法是使用sprintf()
来生成格式字符串。
你可以做的是将宏定义为不包括终端null的长度,然后像这样使用:
#define STR_EVALUATE(x) #x
#define STRINGIFY(x) STR_EVALUATE(x)
#define MAX_ARG_LEN 15
char arg[MAX_ARG_LEN+1] = "";
if (sscanf(arg, "%" STRINGIFY(MAX_ARG_LEN) "X", &input) > 0)
...
或者您可以将MAX_ARG_STRLEN定义为15,将MAX_ARG_LEN定义为MAX_ARG_STRLEN + 1并相应地工作。