美文网首页C/C++知识点
C++小知识:大于0并不意味着等于1

C++小知识:大于0并不意味着等于1

作者: Python编程导师 | 来源:发表于2019-01-10 15:37 被阅读7次

    注:本文所指出的错误例子其实非常简单,任何 C++ 的初学者都能看懂。但是这个错误也非常典型,估计很多非常严肃的代码里面都存在这样的错误。

    这个 Bug 是来自于 CoreCLR 源代码

    错误代码:

    bool operator( )(const GUID& _Key1, const GUID& _Key2) const

      { return memcmp(&_Key1, &_Key2, sizeof(GUID)) == -1; }

    解释:

    你不能将 memcpy()、strcmp() 以及其他一些标准函数的返回值,和 1、-1 这些具体的数字做比较,因为这些函数的返回值只保证大于 0 或者小于 0(译注:而并不保证大于0就等于1,小于0就等于-1)。

    上面那段错误的代码可能在很长时间内都能正常工作。不过那仅仅是因为运气好而已,没什么其他原因。某一天你写的函数很可能突然间就崩溃了 —— 比如,你换了一个编译器编译源代码,或者通过其他方式优化了 memcpy() 函数。然后你的代码就不能正常工作了。

    正确的代码:

    bool operator( )(const GUID& _Key1, const GUID& _Key2) const

      { return memcmp(&_Key1, &_Key2, sizeof(GUID)) < 0; }

    建议:

    不要依赖函数本身的行为。如果文档上说一个函数能返回一个不等于 0 的值,那它就是这么实现的。也就是说这个函数可能返回 -10、2 或者 1024。你可能经常看到函数的返回值就是 -1、0 或者 1,但是这并不能保证它每次都会这么做。

    这个错误是通过 PSV-Studio 静态分析工具扫描分析得到的。错误文本如下:V698 表达式 “memcmp(…) == -1“ 是不正确的。这个函数可能的返回值不一定只有“-1”,而可能是任何负数。请考虑到使用 “memcmp(…) < 0 ”来替换。

    最后还是推荐一下小编的c/c++编程交流群:941636044,有兴趣与小编一起交流的小伙伴可以一起交流哦!

    相关文章

      网友评论

        本文标题:C++小知识:大于0并不意味着等于1

        本文链接:https://www.haomeiwen.com/subject/uauorqtx.html