写在前面
最近心情有些焦虑,说不出的糟糕,但是我不想每天带着负能量生活,,毕竟还有更重要的事情要去做。只有让自己忙碌起来,希望忙碌的生活,可以忘记一些烦恼吧
面向对象简析
之前的文章提到过,接触过java
的人,学习 python 的门槛会极低,因为 java 是一门彻底的面向对象编程语言,在 java 中有句经典的话叫做 万物皆对象,也就是在 oop(面向对象编程) 中,一切事物都可以称之为对象,对象是 类 实例化之后的一块内存空间,一切事物都可以使用 类 来描述,封装了一类事物共有的属性,以及这类事物所能做的事情,即方法。只要实例化类的实例,拿到对象。就能操作对象中存储的属性,以及调用它对应的方法。。。而恰巧,python 的核心编程思想也是 面向对象的,这对于 java 程序员无疑是天大的好事。
例如:可以把人封装为一个类(class),人 具有 姓名,年龄,家庭住址等属性,具备吃饭,睡觉等一系列动作,即方法。当然了,类的划分都是相对的,也可以再细粒度的分类,人也属于动物,也可以再封装一层。。。
下面开始进入 python3 面向对象的傻瓜式学习之旅,滴滴滴~马上开车。。。
python3 类的基本定义
class Cat():
"""模拟小猫的类"""
def __init__(self,name,age):
"""初始化属性name和age"""
self.name = name
self.age = age
def eat(self):
"""小猫会吃饭"""
print(self.name.title() + ' is now eating.')
def sleep(self):
"""小猫会睡觉"""
print(self.name.title() + ' is now sleeping.')
分析:
使用格式
calss+类名():
定义类,缩进的代码块为类的所有内容其中的方法
__init__(self,name,age)
是固定写法,相当于 java 中的构造方法,用于实例化 类实例,传入的参数self
类似于 java 中的 this 指针,即当前类的实例,可以在类中调用任何属性与方法,必须放在参数第一位。剩下的即为类的属性,可以有任意多个,一般在__init__(self,name,age)
中将形参赋值给当前对象的属性,用来初始化类的实例。剩下的
eat()
,sleep(self)
为类的方法,只要实例化类实例,即可随意调用,当然在类中也可以直接用 self 指针直接调用。
创建类实例
类定义好了,可以直接实例化实例,从而访问类属性,以及方法。格式:类名(xxx,yyy,zzz....)
根据_init_()
方法的属性个数,传入对应多个参数值。
my_cat = Cat('willie',6)#实例化类实例,存储在my_cat变量中
注意:实例化过程就是在内存中开辟一块内存空间地址
使用类实例访问类成员属性及方法
一旦类被实例化之后,对象中就存储着类对应的属性值,从而可以直接访问。
print(my_cat)#打印类实例
print(my_cat.name)#访问name属性
print(my_cat.age)#访问age属性
my_cat.eat()#调用eat方法
my_cat.sleep()#调用sleep方法
结果:
<__main__.Cat object at 0x000000000112EEF0>
willie
6
Willie is now eating.
Willie is now sleeping.
从结果中可以看出,Cat('willie',6) 对象实例确实是在内存空间中开辟了一块地址。
给类属性设置默认值
类的全局属性一般是在_init_()
方法中初始化的,当初始化类实例时,python 会帮我们调用_init_()
方法,并生成具备属性值的实例。理论上,我们可以在_init_()
方法中对全局属性做一些操作,比如初始化默认值,属性值递增,甚至可以调用一些初始化别的类实例的方法等等。
def __init__(self,name,age):
"""构造方法,初始化属性name和age"""
self.name = name
self.age = age
self.color = 'blue'#颜色默认值
my_cat = Cat('willie',6)#实例化类实例,存储在my_cat变量中
print(my_cat.color)#结果为 blue
动态修改对象属性值
- 直接访问属性赋值
my_cat.color = 'red'
print(my_cat.color)#结果为 red
- 封裝方法進行動態調用賦值,这种方法其实就类比 java 中的 set 方法。
my_cat.setColor('black')
print(my_cat.color)#结果为 black
继承,面相对象三大特性之一
前面说到,类实可以用来描述一类事物的,而为了达到代码的复用性,面相对象提供了继承的概念,即可以通过继承的方式获取已存在类的属性及方法。被继承方称为父类,继承方称为子类。
定义 Car 父类:
class Car():
"""汽车类"""
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 updata_odometer(self,mileage):
"""动态处理属性值"""
if mileage >= self.odometer_reading:
self.odometer_reading = mileage
else:
print('You can\'t roll back an odometer!')
def increment_odometer(self,miles):
"""属性值递增"""
self.odometer_reading += miles
子类:
class ElectricCar(Car):
"""电动汽车"""
def __init__(self,make,model,year):
"""初始化父类属性"""
super().__init__(make,model,year)
my_tesla = ElectricCar('tesla','model s',2017)
print(my_tesla.get_descriptive_name())
结果:2017 Tesla Model S
简析:ElectricCar 累拥有 Car 类的所有属性及方法,在_init_()
中调用父类 _init_
方法初始化父类属性,其中super
为父类对象,可以使用它访问父类的方法及属性。
定义子类独有的属性及方法
一类事物公有的属性及方法可以封装在父类,以达到复用的效果。除了可以从父类继承公有属性及方法之外,子类还可以定义自己独有的属性及方法。
def __init__(self,make,model,year):
"""初始化父类属性"""
super().__init__(make,model,year)
self.battery_size = 70
def describe_battery(self):
"""子类特有的方法"""
print('This car has a' + str(self.battery_size) + '-kwh battery.')
my_tesla = ElectricCar('tesla','model s',2017)
print(my_tesla.describe_battery())
结果:This car has a 70-kwh battery.
重写父类的方法
有时候父类定义的方法往往不符合子类现有的需求,可以对它进行重写,执行子类特有的逻辑。注意:只要重写了父类的方法,此时调用方法以子类实现为主
def get_descriptive_name(self):
print('重写了父类的方法')
print(my_tesla.get_descriptive_name())
结果肯定是打印 重写了父类的方法
导入类
oop 编程中,每个类都有自己特有的功能,当整个项目也来越复杂的时候,就需要每个类之间相互依赖,正常情况下,都是一个 python 文件存储一个类,当需要依赖别的类时,需要导入。使用格式 from 文件名 import 类名......
,当然了 也可以一个文件存储多个类。
例如:在 car.py 中添加 Car 类
class Car():
"""汽车类"""
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 updata_odometer(self,mileage):
"""动态处理属性值"""
if mileage >= self.odometer_reading:
self.odometer_reading = mileage
else:
print('You can\'t roll back an odometer!')
def increment_odometer(self,miles):
"""属性值递增"""
self.odometer_reading += miles
在 electricCar.py 中添加 ElectricCar 类继承自 Car ,
from car import Car
class ElectricCar(Car):
"""电动汽车"""
def __init__(self,make,model,year):
"""初始化父类属性"""
super().__init__(make,model,year)
self.battery_size = 70
def describe_battery(self):
"""子类特有的方法"""
print('This car has a ' + str(self.battery_size) + '-kwh battery.')
def get_descriptive_name(self):
print('重写了父类的方法')
现在,python 面向对象部分就粗糙的整理好了,然而这趟车还没到达终点,小司机仍需加油开车。。
最后记录今天看到的一句深刻的话:
如果一个人出海遇到狂风暴雨,被变换肆虐的风吹得团团转,你可能会觉得他航行了很远。其实航行得并不远,只是浮沉动荡的时间长而已。
更多原创文章会在公众号第一时间推送,欢迎扫码关注 张少林同学