zoukankan      html  css  js  c++  java
  • ERP程序的公共代码中出现的问题 过度封装不方便维护

    在设计一个ERP程序时,提取公共的代码到一个通用类型库中是必要的。这样可以减少代码重复,提高代码利用率。

    但是,做任何事情都要有个度,有些公共的代码引起了过度封装,反而不利于代码的理解。

    举例说明如下

    public class ConfigHelper
    {
            /// <summary> /// Gets whether the specified path is a valid absolute file path. /// </summary> 
            /// <param name="path">Any path. OK if null or empty.</param> 
            static public bool IsValidPath(string path)
            {
                Regex r = new Regex(@"^(([a-zA-Z]:)|(\))(\{1}|((\{1})[^\]([^/:*?<>""|]*))+)$");
                return r.IsMatch(path);
            }
    
    
            public static string GetString(string key)
            {
                return System.Configuration.ConfigurationManager.AppSettings[key];
            }
    }

    第二个方法 GetString,我以为它的封装是不必要的。调用.NET框架的代码只有一行或简单的数行,对它进行封装,反而会引起理解上的障碍。

    再来看另一个方法,对它的封装,要依据具体的使用场景。

    public static decimal GetDecimal(string key)
    {
                decimal value = default(decimal);
                if ((decimal.TryParse(GetString(key), out value)))
                {
                    return value;
                }
                else
                {
                    return 0m;
                }
    }

    这个方法实现的功能是:把一个字符串转化为数字类型,如果它的值不为数字类型的,则返回默认值0。

    根据需要的场景,这个封装有可能是有必要的,可以减少很多重复的代码。

    欢迎大家给出意见,我觉得这个GetDecimal方法也是多余的,不必要的封装。

  • 相关阅读:
    【转载】Unity 合理安排增量更新(热更新)
    COCOS2D 释放资源的最佳时机
    【转载】利用Unity自带的合图切割功能将合图切割成子图
    用GL画出人物的移动路径
    使用行为树(Behavior Tree)实现游戏AI
    C#学习笔记
    题目:给定一数组 例如:a = [1,2,3,5,2,1] 现用户提供一个数字 请返回用户所提供的数字的所有下标
    算法: 归并排序
    题目:给定两个有序数组,对其进行合并
    数据结构 顺序表实现优先队列 回顾练习
  • 原文地址:https://www.cnblogs.com/JamesLi2015/p/3054122.html
Copyright © 2011-2022 走看看