c – 如何使用sscanf崩溃读取数字?

前端之家收集整理的这篇文章主要介绍了c – 如何使用sscanf崩溃读取数字?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
Cppcheck已经检测到这样的代码中的潜在问题:
float a,b,c;
int count = sscanf(data,"%f,%f,%f",&a,&b,&c);

它说:“scanf没有字段宽度限制可能会崩溃与巨大的数据”.怎么可能?在某些sscanf实现中是否已知错误?我知道数字可能会溢出(数字),但程序怎么会崩溃?这是cppcheck中的假阳性吗?

我发现了一个类似的问题:scanf Cppcheck warning,但答案并不完全令人满意.答案提到类型安全,但这不应该是一个问题.

解决方法

我是Cppcheck开发人员.

是的,这是一个奇怪的崩溃. “巨大的数据”意味着数以百万计的数字.

如果使用–verbose标志,那么cppcheck实际上会写一个通常在linux计算机上崩溃的示例代码.

以下是我的Ubuntu 11.10计算机上的分段错误崩溃的示例代码

#include <stdio.h>

#define HUGE_SIZE 100000000

int main()
{
    int i;
    char *data = new char[HUGE_SIZE];
    for (int i = 0; i < HUGE_SIZE; ++i)
        data[i] = '1';
    data[HUGE_SIZE-1] = 0;
    sscanf(data,"%i",&i);
    delete [] data;
    return 0;
}

对于您的信息,当我在visual studio上尝试此示例代码时,我不会遇到崩溃.

我用g版本4.6.1进行编译.

猜你在找的C&C++相关文章