这与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/