2.2 面向对象编程语言中的类
测试驱动数据库开发
为何对象的类来到应用开发世界的时间要远远比数据库的类早呢?首先,与在应用开发世界相比,在数据库世界中能让类成为必要元素的影响力没有那么强大,这一点先暂且不谈。其次,相比创建数据库实例,我们能够更加容易地建立可靠的方法来在应用会话中创建对象。
2.2.1 类的构建很容易:构建新对象即可
在面向对象编程的世界中,类其实仅有两个职责:创建新对象和析构(destroy)被废弃的对象。就本书的目的而言,析构其实并不重要。然而,对象的创建绝对是重要的。
在像C#、Java或Ruby语言中,当一个类被请求构建一个新的对象时,该构建过程始于一个空的内存块。此时该内存块里保存的内容与该对象毫不相干,所以该类能够直接用构建该对象所需要的内容覆盖之。在某些情况下,此事就像下面这些操作那样简单,即在虚方法表中添加指针,将余下的字节清零,并委托构造方法进行进一步的初始化操作。在另外一些情况下,此事又像下面这个操作那样复杂,即构建结构化数据来指向各种元数据、方法等。
然而,无论如何,此事是如此的复杂,以至于我们不能用一些简单的数学规则在开发人员对设计的表达与创建一个类型的实例所需的精确的步骤集合之间进行转换。
2.2.2 一条途径:必要时析构
对于一个类,开发人员可能会做下面一些事情。这些事情中有许多是与设计有关的。例如,使用测试先行(test-first)的技术从零开始开发一个类;使用现有的测试来重写一个类;修改一个类的测试套件(suite of tests)来改变类的行为。
有些需要在类上做的事情与部署有关,这会产生两种主要的事情,即构建一个新的对象和更新一个现有的对象。这两件事听起来有所不同,并且因为程序员可能必须要分开处理这两种情况,因此认为这两件事有所不同也是有道理的。但是从编译器的角度看,这两件事其实就是同一件事。
在应用开发环境中创建类为何如此容易,这件事的关键在本节开始的描述中已经说明。当一块内存中的字节交给了一个面向对象编程的类后,该类不必在意这块内存里存储的内容,它可以随意将其清零。有些平台能够保证这些字节从一开始就被清零。
这种对象的类永远只能构建新的实例。如果需要升级旧的实例,该怎么办?通常情况下,先找个其他地方保存旧实例的内容,通过关闭应用系统来析构旧的对象,再通过更新容纳这些对象的二进制文件来更新对象的类,启动升级后的应用系统,再通过从某种持久、简化的格式中提取旧状态的方式来创建新的对象。
本文仅用于学习和交流目的,不代表异步社区观点。非商业转载请注明作译者、出处,并保留本文的原始链接。