- 1、本文档共9页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
... 第七章 类及面向对象编程
类是用来创建数据结构和新类型对象的主要机制.本章的主题就是类,面向对象编程和设计不是
本章的重点。本章假定你具有数据结构的背景知识及一定的面向对象的编程经验(其它面向对
象的语言,比如java,c++).(参见第三章,类型和对象 了解对象这个术语及其内部实现的附加信
息) WeiZhong补充:
这本书出版于2001年,虽然Python有极佳的向下兼容性,但我们应该学习必威体育精装版的知识。本
章很多地方已经明显过时,为了保证大家学到新的知识并维持这本书的完整性,我会在必要的
地方说明哪些地方已经过时,哪些地方新增了功能。
Python从2.2起引入了new-style对象模型,以逐步替代已经使用多年的classic对象模型。
由于 classic class 已经行将废止,所以我对本章的例子均作为了适当的修改以支持 new-
style对象模型。
参考文档:《Python In a Nutshell》中的一节Python中的新型类及其实例
1.1.class
11..11..ccllaassss语句
一个类定义了一系列与其实例对象密切关联的属性.典型的属性包括变量(也被称为类变量)和函
数(又被称为方法).
class语句用来定义一个类.类的主体中语句在类定义同时执行.(如 Listing 7.1)
Listing7.1
LLiissttiinngg77..11 类
Toggle line numbers lang=en id=CA-9e9263f625838401ac66df16141fa4d997877a0f_000 dir=ltr 1
class Account(object):
2 一个简单的类
3 account_type = Basic
4 def __init__(self,name,balance):
5 初始化一个新 Account 实例
6 self.name = name
7 self.balance = balance
8 def deposit(self,amt):
9 存款
10 self.balance = self.balance + amt
11 def withdraw(self,amt):
12 取款
13 self.balance = self.balance - amt
14 def inquiry(self):
15 返回当前余额
16 return self.balance
1.2.
11..22.. 访问类属性
类对象作为一个名字空间,存放在类定义语句运行时创建的对象.例如,Account里的内容可以这
样访问: Account.account_type
Account.__init__
Account.deposit
Account.withdraw
Account.inquiry
需要注意的是, class语句并不创建类的实例(例如上边的例子,并没有创建任何帐户).它用来定义
所有实例都应该有的属性.
在类中定义的常规方法的第一个参数总是该类的实例,通常这个参数记为self。你也可能用其它
任何合法的变量名,不过为了符合惯例,你最好还是用self. 类中定义的变量,即类变量,如
account_type, 它被所有该类的实例共享. 虽然类定义了一个名字空间,但这个名字空间并不是为
类主体中的代码服务的.因此在类中引用一个类的属性必须使用类的全名:
Toggle line numbers lang=en id=CA-324c01e7248d0ce536587204e44613_001 dir=ltr
1 class Foo(object):
2 def bar(self):
3 print bar!
4 def spam(self):
5 bar(self) # 错误,引发NameError
6 Foo.bar(self) # 合法的
最后,你不能定义一个不操作实例的方法:
Toggle l
文档评论(0)