这与sscanf usage - how to verify a completed scan vs an aborted scan有关,但这是该问题未涵盖的极端情况。

char entry[] = "V2X_3_accepted";
int d1,d2,ret1,ret2;
ret1 = sscanf(entry,"V2X_%d_expected",&d1);
ret2 = sscanf(entry,"V2X_%d_received",&d2);

预期结果:ret1==0; ret2==0; d1, d2未定义。

实际结果:ret1==1; ret2==1; d1=d2=3

在末尾使用%n将无济于事,因为匹配字符串的长度相等。是否有一些巧妙的技巧可以匹配尾随文本而不执行连续的strncmp或类似操作?

最佳答案

使用"%n"可以正常工作。 @user3121023

建议使用" %n"允许可选的结尾空格(例如'\n')通过"V2X_3_expected\n"并检查%n结果是否为"V2X_3_expected 123"失败。

char entry[] = "V2X_3_accepted";

int d1,d2;
int n1 = 0;
int n2 = 0;

sscanf(entry,"V2X_%d_expected %n",&d1, &n1);
sscanf(entry,"V2X_%d_received %n",&d2, &n2);
if (n1 > 0 && entry[n1] == '\0') Success_expected(d1);
else if (n2 > 0 && entry[n2] == '\0') Success_received(d2);
else Fail(entry);

扫描到达n1说明符后,将"%n"初始化为一个永远不会设置的值。 n1 = 0;在大多数情况下都可以很好地工作,例如使用OP的"V2X_%d_ ..."格式。
n1 = -1; /* and (n1 >= 0 */也可以与" %n"之类的短格式一起使用。

关于c - 匹配sscanf中的尾随文本?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/41221639/

10-12 16:09