如何从此代码中绘制控制流图?

Lea*_*ath 3 c testing unit-testing control-flow-graph

int main() {
    int i, grade = 0;
    printf (" Enter points: \n");
    scanf ("%d", &i);
    if (i >= 50 && i <= 60) grade = 5;
    else if (i > 50 && i <= 60) grade = 6;
    else if (i > 60 && i <= 70) grade = 7;
    else if (i > 70 && i <= 80) grade = 8;
    else if (i > 80 && i <= 90) grade = 9;
    else if (i > 90 && i <= 100) grade = 10;
    char sign = ' ';
    if (grade) {
        int p = i % 10;
        if (grade != 5) {
            if (p >= 1 && p <= 3)
                sign = '-';
            else if (grade != 10 && (p >= 8 || p == 0))
                sign = '+';
        }
        printf (" The grade is %d%c. \n", grade, sign);

    }
    return 0;
}
Run Code Online (Sandbox Code Playgroud)

如何从此代码中绘制控制流图?如果有人能展示这个过程,我将不胜感激.我能够从一个非常简单的案例中得出CFG,但我不能这样做.此外,我需要确定多条件标准的基本路径和测试.这不是一个家庭作业问题,我只是试着理解课程材料.谢谢.

11t*_*ion 9

这是维基百科中CFG的定义,我知道您已经知道了,但是为了完整起见,我将其放在此处

计算机科学中的控制流图(CFG)是使用图形表示法表示程序执行期间可能会遍历的所有路径的表示。

参考:https : //en.wikipedia.org/wiki/Control_flow_graph

以下是路径的定义

路径:CFG(静态)上的节点序列,包括入口节点和出口节点;路径段:沿路径的节点的子序列

参考:http : //web.cs.iastate.edu/~weile/cs513x/4.ControlFlowAnalysis.pdf

因此,绘制一个的原因是确定程序所采用的所有可能路径,这可能有助于我们在不实际运行程序的情况下确定测试覆盖率之类的内容(静态分析)。

以下是绘制CFG时可以遵循的简单规则

  1. 任何语句将成为图中的节点
  2. 所有节点都有一个有向边,要么到达要么离开它们,或者两者都有。入口节点(第一条语句)仅具有输出边缘,而出口节点仅具有输入边缘。
  3. 仅条件语句(如if/else ifswitchloops将具有多个输出边缘。
  4. 从节点出来的所有路径都将在某个点汇聚,最坏的情况是它们会在出口汇聚。

这是一个备忘单,可以更好地解释它

CFG备忘单

现在让我们将程序中的每条语句映射到一个用于表示CFG节点的数字

   int main() {
1.     int i, grade = 0;
2.     printf (" Enter points: \n");
3.     scanf ("%d", &i);
4.     if (i >= 50 && i <= 60)
5.         grade = 5;
6.     else if (i > 50 && i <= 60)
7.         grade = 6;
8.     else if (i > 60 && i <= 70)
9.         grade = 7;
10.    else if (i > 70 && i <= 80)
11.         grade = 8;
12.    else if (i > 80 && i <= 90)
13.         grade = 9;
14.    else if (i > 90 && i <= 100)
15.         grade = 10;
16.    char sign = ' ';
17.    if (grade) {
18.        int p = i % 10;
19.        if (grade != 5) {
20.            if (p >= 1 && p <= 3)
21.                sign = '-';
22.            else if (grade != 10 && (p >= 8 || p == 0))
23.                sign = '+';
           }
24.        printf (" The grade is %d%c. \n", grade, sign);
       }
25.    return 0;
  }
Run Code Online (Sandbox Code Playgroud)

这是按照上面备忘单图表中的说明创建的输出。注意,之前的节点16和24充当了许多条件节点的加入节点。

在此处输入图片说明

信用:我已经使用draw.io创建了上面发布的图像。

注意:绘制CFG的秘诀是对待每个独立于程序的语句,绘制它,然后将其入口和出口链接到图的其余部分。

以下是我遵循的一些初始步骤

  1. 语句1、2和3是无条件的,因此我创建了三个将它们链接在一起的块。 步骤1
  2. 语句4是条件语句。因此,我必须为其创建4个块。首先是语句4,第二和第三条是TRUE,FALSE边,最后一个是JOIN节点。如果为true,则运行语句5;否则,运行语句6。从语句5,我们直接转到语句16,这是我们的连接节点。最终,我们将块4链接到块3的输出边缘。 在此处输入图片说明
  3. 现在,语句5本身是一个条件语句,因此我们再次需要4个块。我们本身已经有一个块5。为此,它的连接节点将是语句16,就好像它的条件为true一样,然后运行语句6并将其直接转到16。 ,即语句7和8的FALSE分支。 第三步

依此类推,我们一直在检查备忘单中的适用节点,并单独创建它们,然后将其链接到先前的节点。


e.h*_*did 5

如果我们应该解释一个流程图,那么我们为什么要绘制它?图表必须如此清晰.

控制流程图

有很多在线工具,你可以输入你的代码,这将给你这样的图表.你可以检查一下.

  • 这不是CFG,而是控制流程图。他们是不同的。 (3认同)