现在的位置: 首页 > 综合 > 正文

表驱动编程方法 table-driven programming 表驱动编程方法 table-driven programming

2017年11月02日 ⁄ 综合 ⁄ 共 1362字 ⁄ 字号 评论关闭

表驱动编程方法 table-driven programming

分类: C/C++ Develop 323人阅读 评论(1) 收藏 举报

      最近写了一段这样的代码。代码的功能是,通过函数function()返回的错误代码,生成一段说明该代码错误的log。

      最开始我的代码是这样写的:

  1. enum error_t{  
  2. ERROR0=0,  
  3. ERROR1,  
  4. ERROR2,  
  5. ERROR3  
  6. };  
  7.   
  8. error_t function()  
  9. {  
  10.    //......  
  11. }  
  12.   
  13. int main()  
  14. {  
  15.     error_t err_code;  
  16.     err_code = function();  
  17.     switch(err_code)  
  18.     {  
  19.        case ERROR0:  
  20.            printf("Success.");  
  21.            break;  
  22.        case ERROR1:  
  23.            printf("Error1 occured.");  
  24.            break;  
  25.        case ERROR2:  
  26.            printf("Error2 occured.");  
  27.            break;  
  28.        case ERROR3:  
  29.            printf("Error3 occured.");  
  30.            break;  
  31.        default:  
  32.            printf("undefined error occured.");  
  33.            break;         
  34.     }  
  35.   
  36.     return 0;  
  37. }  

       这段代码简单的时候,还是可以清楚做了什么的。但是一旦error的类型比较冗长时,代码就不够清晰了。另外,这么长长的一段代码掩盖了代码的主干,颇有宣兵夺主之嫌。

       每个case里面都进行printf,这是一种重复代码的行为。因为它们都进行printf,所以可以提炼出这个共同点。在导师的指导下,改成这样:

  1. enum error_t{  
  2. ERROR0=0,  
  3. ERROR1,  
  4. ERROR2,  
  5. ERROR3  
  6. };  
  7.   
  8. char err_msg[][256] = {  
  9. "Success",  
  10. "Error1 occured.",  
  11. "Error2 occured.",  
  12. "Error3 occured.",  
  13. "Undefined error occured."  
  14. };  
  15.   
  16. void print_err(error_t err_code)  
  17. {  
  18.     printf("%s", err_msg[err_code]);  
  19. }  
  20.   
  21. int main()  
  22. {  
  23.     error_t err_code;  
  24.     err_code = function();  
  25.     print_err(err_code);  
  26.     return 0;  
  27. }  

抱歉!评论已关闭.