在测试我的代码(静态分析)以查看我是否尊重 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/

10-11 21:06