标签:导致 retry nms ++ -- while 循环 字符串 超时
在使用别人的代码时,有一个地方运行得没问题但却一直实现不了我想要得效果
uint8_t FindStr(char* dest,char* src,uint16_t retry_nms)
{
retry_nms/=10; //超时时间
while(strstr(dest,src)==0 && retry_nms--)//等待串口接收完毕或超时退出
{
HAL_Delay(10);
}
if(retry_nms) return 1;
return 0;
}
这是一个简单的在规定时间内在母字符串里寻找子字符串的一个函数,我发现无论母字符串中是否包含子字符串,结果都会回我一个1。我仔细阅读这段代码觉得逻辑上也没什么不对。
于是我在while循环后面加了一个
printf("%64u",retry_nms);
当我设置子字符串不包含在母字符串时,我惊奇地发现这个超时时间居然是65536。细细一想便知是0-1,导致溢出了。
当我往回看while循环条件时,当retry_nms为0时,它将跳出循环并自减一次,这也导致了上述错误的发生。
++在前在后决定了这个自减是先发生还是后发生。
如果初学者实在弄不明白,可以在while循环中进行加减,这样逻辑关系会清晰很多。
同时,通过这个我也学会了一种偷偷藏bug的小技巧。
标签:导致,retry,nms,++,--,while,循环,字符串,超时 来源: https://blog.csdn.net/kasami_/article/details/116374918
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。