size_t是个无符号整数,在for循环中与0、-1比较可能会陷入死循环或者0xffffffff大循环
例如下面代码
size_t len1 = -1;
for(size_t i=0; i<len1 && i<=3; i++)
{
printf("size_t:%d\n", i);
}
for(size_t i=3; i>=0; i--)
{
printf("size_t:%d\n", i);
}
可能本意只是与一个字符串或一个数组比较,而其长度为0,容易造成意外情况。
找到一种好的方法是用ssize_t代替size_t,vs需要增加额外的预编译判断,既方便32位向64位移植,也同时支持windows/linux下的for循环判断
#if defined(_MSC_VER)
#include <BaseTsd.h>
typedef SSIZE_T ssize_t;
#endif
int main(int argc, char* argv[])
{
int count = 0;
size_t len1 = -1;
for(size_t i=0; i<len1 && count<3; i++)
{
printf("size_t:%d\n", i);
count++;
}
ssize_t len2 = -1;
for(ssize_t i=0; i<len2 && i<=3; i++)
{
printf("ssize_t:%d\n", i);
}
getchar();
}
参考:https://blog.youkuaiyun.com/m0_37614810/article/details/119111404
https://blog.youkuaiyun.com/fuxiaoxiaoyue/article/details/82747332
文章讨论了在C/C++编程中,使用size_t类型(无符号整数)与负数进行比较可能导致的死循环问题。作者建议在处理可能为负的长度值时使用ssize_t类型,并提供了在VisualStudio环境下添加预编译条件以支持跨平台的代码示例。这种方法增加了代码的健壮性,有助于防止意外的无限循环。
597

被折叠的 条评论
为什么被折叠?



