(代码大全系列)信息隐藏
为什么我们在写程序的时候这么强调信息隐藏呢?信息隐藏给我们的程序带来了什么样的好处?为什么要使用信息隐藏?明明只需要直接写出变量就好了,为什么还需要特别的去把这个变量变成一个类来把信息隐藏使用呢?
举个简单的例子,假设我们现在需要一个唯一的id,我们可以做的方法就是++g_maxId,但是有没有想过这样做的不好的地方在哪里?如果你需要保存这个id怎么办?需要使用一个已经销毁过的对象的Id怎么办?如果我们要做这些事情的话,就需要修改大量的代码,哪里引用了这个id,我们都需要修改。这就是不使用信息隐藏的一个大的弊端。
那么信息隐藏到底有什么样的好处?最大好处就是减少大量的代码修改量,如果我们在这个地方把Id变成IdType也就是一个新的类,利用 return ++g_maxId来返回id的变量。这里我们可以隐藏Id的类型,还可以根据需要在类里面修改并且不影响引用这个类的调用者。想想如果我们只是原本普通的id,那么改一个类型就需要大量的修改了。
信息隐藏的障碍:
- 过渡分散:其实就是能让很多程序直接访问到这里的数据,通常我们可以通过子程序来做间隔
- 循环依赖:A类与B类相互调用对方的子程序,这样就很难单独测试。
- 类内数据误认为是全局数据:可能多个子程序调用全局数据的,但相互不知道对方做了什么操作。
- 可以察觉的性能损耗
在遇到一些设计难题的时候可以提问一下自己"我该隐藏什么"。