如何 sscanf 以确保缓冲区正是我想要的?
How to sscanf to make sure the buffer is exactly what I wanted?
我想扫描一行并确保其中没有我想要的内容。代码如下所示:
void parse_init_command(char *buffer, command *new_command) {
if (sscanf(buffer,
"%s %d %d %d %d %d %d %d\n",
new_command->name,
&new_command->data[0],
&new_command->data[1],
&new_command->data[2],
&new_command->data[3],
&new_command->data[4],
&new_command->data[5],
&new_command->data[6]) != 8) {
strncpy(new_command->name, "WRONG_INPUT", 15);
}
}
当我收到如下输入时:
INIT 9 11 3 1 1 1 9
一切都很好,但是像这样的输入
INIT 9 11 3 1 1 1 9 s
也接受了。我以为如果我添加 "\n" 一切都会正常工作,因为我知道每个输入行都以 EOL 结尾,但事实并非如此。
如果您的输入总是在末尾有一个换行符,这样的事情就可以做到。该代码需要一个额外的 char
类型并检查它是否为 \n
,以及正确的扫描项目数。它打印 1
表示成功 - 出于本示例的目的,您的函数略有变化。
#include <stdio.h>
typedef struct {
char name[100];
int data[7];
} command;
int parse_init_command(char *buffer, command *new_command) {
char eol = 0;
int num = sscanf(buffer, "%s%d%d%d%d%d%d%d%c",
new_command->name,
&new_command->data[0],
&new_command->data[1],
&new_command->data[2],
&new_command->data[3],
&new_command->data[4],
&new_command->data[5],
&new_command->data[6],
&eol);
return num == 9 && eol == '\n';
}
int main(void)
{
char inp[50];
command rec;
fgets(inp, sizeof inp, stdin);
printf("%d\n", parse_init_command(inp, &rec) );
return 0;
}
来自键盘的程序会话:
INIT 9 11 3 1 1 1 9
1
INIT 9 11 3 1 1 1 9 s
0
请注意,%c
之前没有前导 space,这会导致白色 space 被跳过,从而破坏了拥有它的意义。
我想扫描一行并确保其中没有我想要的内容。代码如下所示:
void parse_init_command(char *buffer, command *new_command) {
if (sscanf(buffer,
"%s %d %d %d %d %d %d %d\n",
new_command->name,
&new_command->data[0],
&new_command->data[1],
&new_command->data[2],
&new_command->data[3],
&new_command->data[4],
&new_command->data[5],
&new_command->data[6]) != 8) {
strncpy(new_command->name, "WRONG_INPUT", 15);
}
}
当我收到如下输入时:
INIT 9 11 3 1 1 1 9
一切都很好,但是像这样的输入
INIT 9 11 3 1 1 1 9 s
也接受了。我以为如果我添加 "\n" 一切都会正常工作,因为我知道每个输入行都以 EOL 结尾,但事实并非如此。
如果您的输入总是在末尾有一个换行符,这样的事情就可以做到。该代码需要一个额外的 char
类型并检查它是否为 \n
,以及正确的扫描项目数。它打印 1
表示成功 - 出于本示例的目的,您的函数略有变化。
#include <stdio.h>
typedef struct {
char name[100];
int data[7];
} command;
int parse_init_command(char *buffer, command *new_command) {
char eol = 0;
int num = sscanf(buffer, "%s%d%d%d%d%d%d%d%c",
new_command->name,
&new_command->data[0],
&new_command->data[1],
&new_command->data[2],
&new_command->data[3],
&new_command->data[4],
&new_command->data[5],
&new_command->data[6],
&eol);
return num == 9 && eol == '\n';
}
int main(void)
{
char inp[50];
command rec;
fgets(inp, sizeof inp, stdin);
printf("%d\n", parse_init_command(inp, &rec) );
return 0;
}
来自键盘的程序会话:
INIT 9 11 3 1 1 1 9
1
INIT 9 11 3 1 1 1 9 s
0
请注意,%c
之前没有前导 space,这会导致白色 space 被跳过,从而破坏了拥有它的意义。