9.类
基本概念———初探类与对象
“什么是人类”、“什么是狗”、“汽车又是什么”……面对这些问题,我们大多数人会从“人类”、“狗”、“汽车”各自所具有的的一些特征出发,将这些特征组合来对这些概念进行定义。比如,我们来看看“人类”的特征,首先每个人都有身高、体重、年龄等一些基本属性;其次人会劳动、会直立行走、会用自己的头脑去创造工具等等这些方法(《现代汉语词典》对人的解释是:“能制造工具、并能熟练使用工具进行劳动的高等动物。”)这些是人类群体区别于其他群体的基本属性与方法,但是通过对这些通用行为的概括总结只构成了对“人类”这个抽象概念的定义——我们知道了眼前的这个对象是个人。这个对象同时是一个实体,TA所有的不仅仅是上述的通用行为,还有着自己的个性特征,如眼前这个对象是个摄影高手;另一个对象不会拍照但是个Python高手。面向对象编程中,我们编写表示现实世界中的事物和情景的类,定义这一大类对象都有的通用行为;然后再基于类创建对象,每个对象都自动具备这种通用行为,根据需要我们可以赋予每个对象独特的个性。由此可见,类描述了一组有相同特性(属性)和相同行为(方法)的对象。根据类来创建对象的过程称为实例化。
类(Class):用来描述具有相同的属性和方法的对象的集合。它定义了该集合中每个对象所共有的属性和方法。对象是类的实例。
实例化:创建一个类的实例,类的具体对象。
9.1创建和使用类
class ClassName: #类名
class_suite #类体/语句
9.1.1创建Dog类
关于self的几个要点:
1、self在类方法中必不可少
2、self不是Python的关键字,可以换成其他词
3、self代表的是类的实例,代表当前对象的地址,而self.class则指向类
9.1.2根据类创建实例
创建一个特定小狗实例:
1、利用句点法访问属性
2、利用句点法调用方法
3、创建多个实例
可按需求根据类创建任意数量的实例,以下再创建一个your_dog实例:
#课后习题
9.2 使用类和实例
类编写好后,大部分时间都将花在使用根据类创建实例上。我们需要执行一个重要的任务是修改实例中的属性——可以直接修改,也可以编写方法以特定的方式进行修改。
9.2.1 Car类
9.2.2 给属性指定默认值
类中每个属性都必须有初始值,哪怕这个值是0或者空字符串。
9.2.3 修改属性的值
1.直接修改属性的值
要修改属性的值,最简单的方法是通过实例直接访问它。
2.通过方法修改属性的值
无需直接访问属性,而可将值传递给一个方法,由它在内部进行更新。
3.通过方法对属性的值进行递增
有时候需要将属性值递增特定的量,而不是设置为全新的值。
#课后习题
代码:
# Hello World program in Python
# -- coding: utf-8 --
"""9-4 就餐人数"""
class Restaurant():
"""Defining Restaurants"""
def __init__(self,restaurant_name,cuisine_type):
"""Initializing a restaurant name and cuisine type"""
self.restaurant_name=restaurant_name
self.cuisine_type=cuisine_type
self.number_served=500
def describe_restaurant(self):
"""Describing the restaurant"""
print(self.restaurant_name+" serves "+self.cuisine_type+".")
def open_restaurant(self):
"""Stating the restaurant is open"""
print(self.restaurant_name+" is now open!")
def restaurant(self):
"""Statement showing how many customers have been served"""
print("This restaurant has served " + str(self.number_served) + " customers.")
def set_number_served(self):
"""Method that sets the number served"""
set_number_served = 400
print("This restaurant has served " + str(set_number_served) + " customers.")
def increment_number_served(self):
self.number_served += 432
print("This restaurant has served " + str(self.number_served) + " customers.")
KFC=Restaurant('KFC','fast food')
KFC.describe_restaurant()
KFC.open_restaurant()
KFC.restaurant()
KFC.set_number_served()
KFC.increment_number_served()
代码:
# Hello World program in Python
# -- coding: utf-8 --
"""9-5 尝试登录次数"""
class User():
def __init__(self,first_name,last_name,age,username):
self.first_name=first_name
self.last_name=last_name
self.age=age
self.username=username
self.login_attempts=0
def describe_user(self):
print("Name: "+self.first_name.title()+" "+self.last_name.title())
print("Age: "+str(self.age))
print("Username: "+self.username.title())
def greet_user(self):
print("Welcome back "+self.username.title()+"!"+"\n")
def increment_login_attempts(self):
self.login_attempts+=1
def reset_login_attempts(self):
self.login_attempts=0
user=User('emma','woodhouse',16,'wood')
user.describe_user()
user.greet_user()
for n in range(5):
user.increment_login_attempts()
print("User's login attempts: "+str(user.login_attempts))
user.reset_login_attempts()
print("Reset user's attempts: "+str(user.login_attempts))
9.3 继承
编写类时,并非总是要从空白开始。如果要编写的类是另一个现成类的特殊版本,可使用继承。
一个类继承另一个类时,它将自动获得另一个类的所有属性和方法;原有的类称为父类,而新类称为子类。
子类继承了其父类的所有属性和方法,同时还可以定义自己的属性和方法。
9.3.1 子类的方法__init__()
创建子类的实例时,Python首先需要完成的任务是给父类的所有属性赋值。子类的__init_()需要父类施以援手。
9.3.2 Python2.7中的继承
在Python2.7中,定义子类时,定义的父类括号中必须要包含object关键字:
9.3.3 给子类定义属性和方法
让一个类继承另一个类后,可添加区分子类和父类所需的新属性和方法。对于子类的特殊化程度没有任何限制,可以根据需要添加任意数量的属性和方法。
当然如果是共有的属性和方法则加入到父类之中。这样使用父类时将获得相应的功能,而子类只包含处理相关对象的特有属性和行为的代码。
9.3.4 重写父类的方法
对于父类的方法,只要它不符合子类模拟的实物的行为,都可对其进行重写。对此,可在子类中定义一个与要重写的父类方法同名的方法。这样,Python将不会考虑这个父类方法,而只关注在子类中定义的相应方法。
9.3.5 将实例用作属性
使用代码模拟实物时,你可能会发现自己给类添加的细节越来越多:属性和方法清单以及文件都越来越长。在这种情况下,可能需要将类的一部分作为一个独立的类提取出来。你可以将大型类拆分成多个协同工作的小类。
#课后习题
代码:
# Hello World program in Python
# -- coding: utf-8 --
class Car(object):
def __init__(self,make,model,year):
self.make=make
self.model=model
self.year=year
self.odometer_reading=0
def get_descriptive_name(self):
long_name=str(self.year)+' '+self.make+' '+self.model
return long_name.title()
def read_odometer(self):
print "This car has "+str(self.odometer_reading)+" miles on it."
def update_odometer(self,mileage):
if mileage>=self.odometer_reading:
self.odometer_reading=mileage
else:
print "You can't roll back an odometer!"
class Battery():
def __init__(self,battery_size=70):
self.battery_size=battery_size
def describe_battery(self):
print "This car has a "+str(self.battery_size)+"-kwh battery."
def get_range(self):
if self.battery_size == 70:
range=240
elif self.battery_size == 85:
range=270
message="This car can go approximately "+str(range)
message+=" miles on a full charge."
print(message)
def upgrade_battery(self):
if self.battery_size <85:
self.battery_size=85
class ElectricCar(Car):
def __init__(self,make,model,year):
super(ElectricCar,self).__init__(make,model,year)
self.battery=Battery()
my_tesla=ElectricCar('tesla','model s',2016)
print(my_tesla.get_descriptive_name())
my_tesla.battery.describe_battery()
my_tesla.battery.get_range()
my_tesla.battery.upgrade_battery()
my_tesla.battery.get_range()