天天看点

VBA中什么是类,什么是对象

作者:VBA语言専攻

【分享成果,随喜正能量】想一想,自己造下的、还没忏悔清净的恶有多少?要想临终不随恶趣,有多困难?按照多数人目前的情况来看,根本没有不堕落三恶趣的把握。但是,只要你一心依止阿弥陀佛,就可以在这一生结束后直接生到净土,彻底脱离恶趣,乃至永超生死苦海。。

《VBA中类的解读及应用》教程【10165646】是我推出的第五套教程,目前已经是第一版修订了。这套教程定位于最高级,是学完初级,中级后的教程。

类,是非常抽象的,更具研究的价值。随着我们学习、应用VBA的深入,有必要理解这些抽象的理论知识。对象,类,过程,方法,属性,事件,接口,接口如何实现等等。掌握了这些理论,不仅对于VBA这种寄生语言的实质有所深入的理解,也对自然界的很多事物将同样有所感悟。目前,这套教程程序文件已经通过32位,64位两种office系统测试。

这套教程共两册,八十四讲,今后一段时间会给大家陆续推出修订后的教程内容。今日的内容是:VBA中什么是类,什么是对象

VBA中什么是类,什么是对象

第一讲 什么是类,什么是对象

大家好,在我之前的教程中分别讲了“VBA代码解决方案”“VBA数据库解决方案”“VBA字典和数组解决方案”,通过对这三套教程的学习,我们对VBA的基本知识和基本的操作能有了一定的了解。这套教材是在前面教材基础上的继续,希望大家在学习前面教材的基础上再学习本套教材。这套教程,我们讲解VBA的高级内容:VBA中类的解读及应用。今日的内容是第一讲:什么是类,什么是对象。

1 什么是类

类是对象的“灵魂”。对象可以是任何事物,而类不会做任何事情,也不会占用内存,只有当类成为对象并使用Set语句和New关键字实例化为具体对象后,才能做事情并占用内存。

把类实例化为具体对象的语法为:

Dim C As Class

Set C=New Class

上述语句创建了一个名为C的对象,该对象的数据类型为定义的类Class。其特点是:

1) 使用New关键字,可以创建任意数量类的新实例,并且能够将其存储在Collection对象中。

2) 使用Property Let、Set、Get语句,可以编写代码验证赋给类元素的值,并且可以编写当值改变时执行的相应代码。例如,能够编写代码确保某个值为要求的特性。

3) 类可以定义方法(使用Sub过程和Function过程),执行某项动作。

  • 注意点:类与用户自定义类型的区别,下面给出了自定义数据类型的特点,可以很明显的看出两者的不同:

1) 在编译时必须声明所有的自定义类型变量。可以使用动态数组来处理多个自定义类型,但须使用Redim Preserve关键词。

2) 不能在运行时添加新的自定义类型变量。

3) 不能控制赋给自定义类型中元素的值。如只能定义为整数,但假如要求是大于5的值无法进行控制。

4) 自定义类型只是静态地存储数据。

2 什么是类模块,类属性和方法

类模块由属性和方法组成,类本身类似于名词;属性可以当作形容词,用来描述类;方法则为动词,执行操作

3 类和对象的比较

让我们先来看一条非常简单的程序,亲身体会一下类的庐山真面目:

Sub mynzclass1_1() '第一讲 什么是类,什么是对象

Sheets("1").Activate

Range("A1").Value = "Hello,world"

End Sub

上面代码的第二句:Range("A1").Value = "Hello,VBA world",我们把这这句代码全部放开,把隐藏的补充完整,看看是什么样子:

Application.ActiveWorkbook.ActiveSheet.Range("A1").Value="Hello,VBA world"

我们解释一下:

1) Range("A1")为对象,指定单元格.

2) Range("A1")前面,ActiveSheet也是对象,指定了哪个工作表。

3) ActiveSheet前面又有一个对象ActiveWorkbook,指定了是哪个工作薄,

4) ActiveWorkbook前面还有一个Application,指定的是哪个应用。

那么其中的Value是什么?Value是一个Range("A1")这个对象的一个属性。那它是从哪来的呢?它是由Range类定义的。那么range是类还是对象呢?别急,我慢慢讲解,希望大家通过我的讲解能理解类和对象的关系。

在上面的讲解中,我们提到实例化类为具体对象的过程,其实在mynzclass_1引用了一个Range类,并将之实例化后修改了它的属性。而在例子中,我们只不过是将这一切都隐藏起来,直接对一个对象Range("A1")修改它的属性,但Range("A1")这个对象正是引用了Ragne这个类,才具有了Range类的属性"Value"。

我们把上面的代码转换一下:

Sub mynzclass1_2() '第一讲 什么是类,什么是对象

Sheets("1").Activate

Dim RA As Range '引用一个Range类

Set RA = Range("A1") 'set将类实例化

RA.Value = "Hello,world" 'RA是一个对象了

Set RA = Nothing '将实例化销毁

End Sub

代码截图:

VBA中什么是类,什么是对象

代码的运行:

VBA中什么是类,什么是对象

上述第二段代码是上面mynzclass1_1的原始代码,从中我们看出类本身并不直接为我们做什么,但是,它却又一直默默地隐藏在幕后规化着我们的动作。是的,这就是类。它是通过对象的方式展现在我们的面前,让我们无时无刻不与之交流,却又常常在不经意间忽视了它的存在。

现在,再回到mynzclass1_1去看,就会很容易的发现,ActiveSheet实际引用了Worksheet类、ActiveWorkbook引用了Workbook类,而Application则引用了和它同名的Application类(这也正是我们会经常被混淆的一个概念,一个对象可以和被它所引用的类同名),原来我们在短短一个赋值的语句中,已经在与这么多的类打交道。

那我们又要怎样来区分类和对象呢?其实它们经常成对地出现在我们面前,只是一个是看得见摸得着的,一个却深藏不露。我们可以这样去理解类与对象:类是一个概念或是一种定义,每个类拥有其自己的特征和行为方式,而对象就是某个类的实例。所以类是对象的“灵魂”,它无处不在,而你却看不到它。

比如:汽车。如果作为类:汽车的定义为有四个或者四个以上轮子,人能够坐在上面,操作它行走的工具(好难的定义)。这个时候“汽车类”是有自己的属性,如:汽车的前轮(是负责转向的)。汽车的前玻璃(是负责挡风的)等等。这里的“汽车”是一个概念抽象的概念。

而我们通常指的汽车是作为对象:如丰田汽车,就是汽车类中的一个大对象,这个大对象中还有小的对象,如“威驰FS”对象,属性:轮子是某某牌子的,前挡风玻璃是某某牌子的。这些就是很具体的属性值了。

VBA中什么是类,什么是对象

今日内容回向:

1 什么是类?

2 类和对象的联系是什么?

本讲内容参考程序文件:VBA-CLASS(1-28).xlsm

VBA中什么是类,什么是对象

我20多年的VBA实践经验,全部浓缩在下面的各个教程中:

VBA中什么是类,什么是对象

【分享成果,随喜正能量】人生的路上离不开朋友,有一个值去珍惜和记挂的朋友,便是人生的福气。。