美文网首页Java技术分享
傻瓜式学Python3——面向对象

傻瓜式学Python3——面向对象

作者: 张少林同学 | 来源:发表于2017-09-08 21:12 被阅读240次
    来自网络.jpg

    写在前面

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

    面向对象简析

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

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

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

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

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

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

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

    张少林同学.jpg

    相关文章

      网友评论

        本文标题:傻瓜式学Python3——面向对象

        本文链接:https://www.haomeiwen.com/subject/znpjjxtx.html