我最近(几个月前)换了工作,并继承了一个代码库,该代码库尽可能多地违反了 SOLID 原则中的每一项。似乎编写此代码的人决定详细研究每一个良好的编码实践,并尽可能频繁、最彻底地违反它们。
我是这个产品的唯一开发者——组织中没有人知道代码,而且代码库太大太复杂,无法完全重写。我正在研究我可以做出的最高价值的改变,以使代码库变得灵活和健壮。放弃该产品也不是一种选择。
产品中所有问题的根源都源于一组核心业务逻辑数据结构的类。这些类有很多问题,但我真正感兴趣的是以下内容:
public static class NetCollection
{
private static Logger LogFile { get { return Logger.GetMethodLogger(2); } }
// Declare local variables.
private static Dictionary<string, NetObject> netObjectHashTable;
private static Dictionary<string, NetTitle> titlePropertyHashTable;
private static Dictionary<string, NetObject> referenceDataHashTable;
private static Dictionary<int, SortedDictionary<string, int>> picklistHashTable;
public static IEnumerable<NetObject> NetObjects
{
get
{
return netObjectHashTable.Values;
}
}
static NetCollection()
{
netObjectHashTable = new Dictionary<string, NetObject>();
titlePropertyHashTable = new Dictionary<string, NetTitle>();
referenceDataHashTable = new Dictionary<string, NetObject>();
picklistHashTable = new Dictionary<int, SortedDictionary<string, int>>();
}
public static void AddNetObject(NetObject newObject)
{
if (newObject == null)
return;
if (newObject.TitleType == "Reference Data")
{
// Check if hash table contains key
if (!referenceDataHashTable.ContainsKey(newObject.ID.ToString()))
{
referenceDataHashTable.Add(newObject.ID.ToString(), newObject);
}
}
else
{
// Check if hash table contains key
if (!netObjectHashTable.ContainsKey(newObject.ID.ToString()))
{
netObjectHashTable.Add(newObject.ID.ToString(), newObject);
}
}
}
}
为了简洁起见,我已经从这个类中剪掉了很多其他的方法。
如您所见,围绕这个类存在大量问题(在静态类中存储状态是一种巨大的代码气味——围绕该类编写整个应用程序简直是疯了)。
我目前的意图是将这个类重构为一个适当的单例类(并最终成为一个常规类,以便我可以使用户能够同时打开多个文档)。
我应该这样做吗?
进行此更改的最大风险是什么?我可以采取任何方法来降低进行此更改的风险吗?