zoukankan      html  css  js  c++  java
  • python 面向對象

    概述:

    • 类(Class): 用来描述具有相同的属性和方法的对象的集合。它定义了该集合中每个对象所共有的属性和方法。对象是类的实例。
    • 类变量:类变量在整个实例化的对象中是公用的。类变量定义在类中且在函数体之外。类变量通常不作为实例变量使用。
    • 数据成员:类变量或者实例变量, 用于处理类及其实例对象的相关的数据。
    • 方法重写:如果从父类继承的方法不能满足子类的需求,可以对其进行改写,这个过程叫方法的覆盖(override),也称为方法的重写。
    • 局部变量:定义在方法中的变量,只作用于当前实例的类。
    • 实例变量:在类的声明中,属性是用变量来表示的。这种变量就称为实例变量,是在类声明的内部但是在类的其他成员方法之外声明的。
    • 继承:即一个派生类(derived class)继承基类(base class)的字段和方法。继承也允许把一个派生类的对象作为一个基类对象对待。例如,有这样一个设计:一个Dog类型的对象派生自Animal类,这是模拟"是一个(is-a)"关系(例图,Dog是一个Animal)。
    • 实例化:创建一个类的实例,类的具体对象。
    • 方法:类中定义的函数。
    • 对象:通过类定义的数据结构实例。对象包括两个数据成员(类变量和实例变量)和方法。

    面向对象的三大特性是指:封装、继承和多态。

    一、封装

    封装,顾名思义就是将内容封装到某个地方,以后再去调用被封装在某处的内容。

    所以,在使用面向对象的封装特性时,需要:

    • 将内容封装到某处
    • 从某处调用被封装的内容

    二、继承

    继承,面向对象中的继承和现实生活中的继承相同,即:子可以继承父的内容。

    对于面向对象的继承来说,其实就是将多个类共有的方法提取到父类中,子类仅需继承父类而不必一一实现每个方法

    Python的类如果继承了多个类,那么其寻找方法的方式有两种,分别是:深度优先广度优先

    • 当类是经典类时,多继承情况下,会按照深度优先方式查找
    • 当类是新式类时,多继承情况下,会按照广度优先方式查找

    三、多态 

     Pyhon不支持Java和C#这一类强类型语言中多态的写法,但是原生多态,其Python崇尚“鸭子类型”

    面向对象的应用场景:

    多函数需使用共同的值,如:数据库的增、删、改、查操作都需要连接数据库字符串、主机名、用户名和密码

    class SqlHelper:
    
        def __init__(self, host, user, pwd):
    
            self.host = host
            self.user = user
            self.pwd = pwd
    
        def 增(self):
            # 使用主机名、用户名、密码(self.host 、self.user 、self.pwd)打开数据库连接
            # do something
            # 关闭数据库连接
    
        def 删(self):
            # 使用主机名、用户名、密码(self.host 、self.user 、self.pwd)打开数据库连接
            # do something
            # 关闭数据库连接
    
        def 改(self):
            # 使用主机名、用户名、密码(self.host 、self.user 、self.pwd)打开数据库连接
            # do something
            # 关闭数据库连接
    
        def 查(self):
        # 使用主机名、用户名、密码(self.host 、self.user 、self.pwd)打开数据库连接
            # do something
            # 关闭数据库连接# do something
    
    Demo
    

    需要创建多个事物,每个事物属性个数相同,但是值的需求
    如:张三、李四、杨五,他们都有姓名、年龄、血型,但其都是不相同。即:属性个数相同,但值不相同

    class Person:
    
        def __init__(self, name ,age ,blood_type):
    
            self.name = name
            self.age = age
            self.blood_type = blood_type
    
    
        def detail(self):
            temp = "i am %s, age %s , blood type %s " % (self.name, self.age, self.blood_type)
            print temp
    
    zhangsan = Person('张三', 18, 'A')
    lisi = Person('李四', 73, 'AB')
    yangwu = Person('杨五', 84, 'A')
    
    Demo
    
    class bar():
        def foo(self,connect):
            print(self.name,self.age,self.gender,connect)
    
    h = bar()
    h.name = 'hua'
    h.age = 22
    h.gender = 'f'
    h.foo('小呀嘛小二郎')
    h.foo('ffffff')
    
    ******************************************
    class person():
        def __init__(self,name,age): #構造方法
            self.n=name
            self.a=age
            self.x='AB'
        def foo(self):
            print('%s-%s'% (self.n,self.a))
    
    hua = person('lihuan', 22)
    hua.foo()
    
    yang = person('yangzi' , 24)
    yang.foo()
    
    
    **************************************
    
    class F:
        def f1(self):
            print('爸爸')
    class S(F):  #繼承
        def s1(self):
            print('兒子')
    
    obj = S()
    obj.s1()
    obj.f1()
    
    ********************************
    
    class F:
        def f1(self):
            print('爸爸')
        def f2(self):
            print('哈哈')
    class S(F):  #繼承
        def s1(self):
            print('兒子')
            super(S,self).f2()   #執行父類的f2方法
            F.f1(self)           #執行父類的f1方法
        def s2(self):
            print('二二而')
    
    obj = S()
    obj.s1()
    obj.f2()
    
    **********************************
    
    
    class Foo:
        def bar(self):
            print('你好')
    
        @staticmethod
        def sta():
            print('哈哈')
        @staticmethod
        def stat(a ,b):
            print(a, b)
    
        @classmethod
        def bbb(cls):
            #cls類名
            print(cls)
            print('川島穎子')
    
    
        @property
        def ccc(self):
            return '加藤鷹'
        @ccc.setter
        def ccc(self, val):
            print(val)
    
        @ccc.deleter
        def ccc(self):
            print('川島芳子')
    
    Foo.sta()
    Foo.stat('蒼井空', '武藤蘭')
    Foo.bbb()
    obj = Foo()
    r = obj.ccc
    print(r)
    
    obj.ccc = '櫻之海'
    
    del obj.ccc
    
    
    *****************************************
    
    class page_name:
    
        def __init__(self, current_page):
            try:
                p = int(current_page)
            except Exception as e:
                p = 1
    
            self.page = p
        @property
        def start(self):
            val = (self.page - 1) * 10
            return val
        @property
        def end(self):
            val = self.page * 10
            return val
    
    li = []
    for i in range(1000):
        li.append(i)
    
    while True:
        p = input('請輸入要查看的頁碼:')
        obj = page_name(p)
        print(li[obj.start: obj.end])
    
    
    ****************************************
    
    異常處理
    def fun():
        while True:
            ret = 0
            try:
                 li=[11,22]
                 li[888]
                 int('wer')
            except IndexError as e:
                print('IndexError' , e)
            except ValueError as e:
                print('ValueError', e)
            except Exception as e:
                print(e)
            else:
                ret  =1
                print('elese')
            finally:
                print('.....')
        return ret
    r = fun()
    if r ==0:
        print('500')
    else:
        pass
    
    无论你选择做什么,追求完美的程度决定你成就的高度。
  • 相关阅读:
    性能测试相关
    centos7 设置定时器 crond
    大杀器Bitset
    树形DP
    双线程DP
    状态压缩DP
    斜率优化DP
    01分数规划
    二分和三分
    uva11549 Floyd判圈法
  • 原文地址:https://www.cnblogs.com/chiyhua/p/12726167.html
Copyright © 2011-2022 走看看