python3 面向对象_傻瓜式学Python3——面向对象

a06f7180c332

来自网络.jpg

写在前面

最近心情有些焦虑,说不出的糟糕,但是我不想每天带着负能量生活,,毕竟还有更重要的事情要去做。只有让自己忙碌起来,希望忙碌的生活,可以忘记一些烦恼吧

面向对象简析

之前的文章提到过,接触过java的人,学习 python 的门槛会极低,因为 java 是一门彻底的面向对象编程语言,在 java 中有句经典的话叫做 万物皆对象,也就是在 oop(面向对象编程) 中,一切事物都可以称之为对象,对象是 类 实例化之后的一块内存空间,一切事物都可以使用 类 来描述,封装了一类事物共有的属性,以及这类事物所能做的事情,即方法。只要实例化类的实例,拿到对象。就能操作对象中存储的属性,以及调用它对应的方法。。。而恰巧,python 的核心编程思想也是 面向对象的,这对于 java 程序员无疑是天大的好事。

例如:可以把人封装为一个类(class),人 具有 姓名,年龄,家庭住址等属性,具备吃饭,睡觉等一系列动作,即方法。当然了,类的划分都是相对的,也可以再细粒度的分类,人也属于动物,也可以再封装一层。。。

下面开始进入 python3 面向对象的傻瓜式学习之旅,滴滴滴~马上开车。。。

a06f7180c332

开车.png

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 面向对象部分就粗糙的整理好了,然而这趟车还没到达终点,小司机仍需加油开车。。

最后记录今天看到的一句深刻的话:

如果一个人出海遇到狂风暴雨,被变换肆虐的风吹得团团转,你可能会觉得他航行了很远。其实航行得并不远,只是浮沉动荡的时间长而已。

更多原创文章会在公众号第一时间推送,欢迎扫码关注 张少林同学

a06f7180c332

张少林同学.jpg

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值