1

我正在尝试计算一些Cyclomatic Complexity,因此尝试绘制控制流图。首先,我试图使其成为一种相当简单的方法。

首先,我尝试仅将其绘制为这样的尝试部分: 流程图

方法如下:

    [HttpPost]
    public ActionResult GraphMethod([FromForm]string str)
    {
        try
        {
            int affectedRows = this._copyManager.CreateCopy(str);
            if (affectedRows < 1) return BadRequest("Error!");

            return Ok();
        }
        catch (Exception ex)
        {
            return BadRequest(ex.Message);
        }
    }

我将如何扩展它以包含整个方法和尝试部分?

这是我的第一个控制流图,所以如果我搞砸了,我也想知道。

4

2 回答 2

1

就我而言,我建议您使用此代码,越简单,越高效

[HttpPost]
public ActionResult GraphMethod([FromForm]string str)
{       
        if (this._copyManager.CreateCopy(str) < 1) 
            return BadRequest("Error!");

        return Ok();      
}
于 2019-05-21T09:36:56.743 回答
1

我会创建一个TryCreateCopy方法并做一些与@saya imad 的回答非常相似的
事情,如下所示:

[HttpPost]
public ActionResult GraphMethod([FromForm]string str)
{ 
    // These two if statements can be concatenated into one, 
    // but that would be a bit hard to read
    if (this._copyManager.TryCreateCopy(str, out var affectedRows))
        if (affectedRows > 1)
            return Ok();

    return BadRequest("Error!");
}

// _copyManager Method, there's probably a better way for you
public bool TryCreateCopy(string str, out int affectedRows)
{
    try
    {
        affectedRows = CreateCopy(str);
    }
    // Please also don't do `catch (Exception)`, 
    // if you know which exception gets thrown always catch that
    catch (Exception e)
    {
        affectedRows = -1;
        return false;
    }

    return true;
}

当创建副本而未引发异常时,TryCreateCopy 方法返回 true,如果已抛出异常,则返回 false* 和带有受影响行数的 out 变量


* 可能有比我向您展示的更好的方法(例如 validate 方法?),因为 try/catch 非常耗费资源

于 2019-05-21T10:32:04.153 回答