在测试我的代码(静态分析)以查看我是否尊重 misra c++ 2008 时,我收到以下错误
该功能看起来像
int* Dosomething(string v)
{
int* retvalue = NULL;
if( 0 == exists(v) )
{
throw("error: value doesn't exist");
}
else
{
retvalue = dosomecomputations(v);
}
return retvalue;
}
我真的需要抛出一个异常,因为调用者会根据错误做一些事情。可能的错误列表可能很大,而且不仅仅是此代码示例中的值不存在。
我该如何管理?我认为在这种情况下,我使用的工具不应将其视为对 misra 的不遵守。
感谢您的意见。
罗尼。
最佳答案
以下代码不应报告应用了 MISRA C++ 2008 规则的任何警告/错误。所以很可能是你的工具有问题 - 或者发布的代码不是受影响的部分。
#include <string>
int exists(std::string v){ (void)v; return 1; }
int* dosomecomputations(std::string v){ (void)v; return NULL; }
int* dosomething(std::string v){
int* retvalue = NULL;
if( 0 == exists(v) ){
throw("error: value doesn't exist");
}else{
retvalue = dosomecomputations(v);
}
return retvalue;
}
尝试使用您的 MISRA 检查器仅检查上面的代码段,看看它是否仍在报告任何内容。如果问题仍然存在,我会联系工具供应商并向他询问该问题。
关于c++ - MISRA-C++ :2008[8-4-3] : return in all exit path in function,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/20425065/