python面向对象继承.私有化

本文介绍了Python面向对象编程中的继承和私有化。通过示例展示了单继承、多继承的概念,解释了如何调用父类方法以及私有属性和方法的使用。同时,探讨了私有属性的修改和访问控制,以及类属性和实例属性的区别。最后,提到了`__new__`方法和单例模式的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

继承:

在程序中,继承描述的是多个类之间的所属关系。

如果一个类A里面的属性和方法可以复用,则可以通过继承的方式,传递到类B里。

那么类A就是基类,也叫做父类;类B就是派生类,也叫做子类。

单继承:子类只继承一个父类

说明:

虽然子类没有定义__init__方法初始化属性,也没有定义实例方法,但是父类有。所以只要创建子类的对象,就默认执行了那个继承过来的__init__方法

总结:

子类在继承的时候,在定义类时,小括号()中为父类的名字

父类的属性、方法,会被继承给子类

多继承:子类可以继承多个父类

说明

多继承可以继承多个父类,也继承了所有父类的属性和方法

注意:如果多个父类中有同名的 属性和方法,则默认使用第一个父类的属性和方法(根据类的魔法属性mro的顺序来查找)

多个父类中,不重名的属性和方法,不会有任何影响。

继承demo:

class Master(object):
    def __init__(self):
        self.kongfu="古法煎饼果子配方" #实例变量,属性
    def make_cake(self):                #实例方法,方法
        print("[古法]按照<%s>制作了一份煎饼国子",self.kongfu)
    def dayandai(self):
        print("大烟袋")
class school(object):
    def __init__(self):
        self.kongfu = "现代煎饼果子配方"
    def make_cake(self):                #实例方法,方法
        print("[现代]按照<%s>制作了一份煎饼果子"%self.kongfu)
    def xiaodayandai(self):
        print("小烟袋")
class Prence(school,Master):#继承多个父类
    def __init__(self):
        self.kongfu="猫氏煎饼果子配方"
      def make_cake(self):
          print("按照<%s>制作了一份煎饼果子"%self.kongfu)
 
 
damao=Prence()
print(Prence.__mro__)
print(damao.kongfu)
damao.make_cake()
damao.dayandai()
damao.xiaodayandai()

调用父类方法super()

课后作业1:
# 实现一个简单的金融类,要求功能有:
# 父类股票类,控股法输出股票买入和卖出;
# 子类(公募机构)继承自父类,操作输出公募机构买入和卖出;
# 子类(私募机构)继承自父类,操作输出私募机构买入和卖出;
# 创建对象实现相关方法的调用
# 尝试使用尽可能多的方法调用父类方法
# 子类(公募机构)学会了父类的控股法操作
# 子类(私募机构)学会了父类的控股法操作并专研了自己的输出股票和私募买入和卖出(重写)
 
class guPiao(object):
    def maiRu(self):
        print("控股法股票买入")
    def maiChu(self):
        print("控股法股票卖出")
 
class gongCuanJiGou(guPiao):
    def maiRu(self):
        print("公募机构买入")
    def maiChu(self):
        print("公募机构卖出")
    def fulei(self):
        guPiao.maiChu(self)
        guPiao.maiRu(self)
class siCuanJiGou(guPiao):
    def maiRu(self):
        print("私募机构买入")
    def maiChu(self):
        print("私募机构卖出")
    def fulei(self):
        guPiao.maiChu(self)
        guPiao.maiRu(self)
    def chongxie(self):
        print("自己研制的方法")
aa=siCuanJiGou()
bb=gongCuanJiGou()
 
bb.fulei()
bb.maiRu()
bb.maiChu()
aa.fulei()
aa.maiRu()
aa.maiChu()
aa.chongxie()

封装:

封装的意义:

将属性和方法放到一起做为一个整体,然后通过实例化对象来处理;

隐藏内部实现细节,只需要和对象及其属性和方法交互就可以了;

对类的属性和方法增加 访问权限控制。

私有权限:在属性名和方法名 前面 加上两个下划线 __

类的私有属性 和 私有方法,都不能通过对象直接访问,但是可以在本类内部访问;

类的私有属性 和 私有方法,都不会被子类继承,子类也无法访问;

私有属性 和 私有方法 往往用来处理类的内部事情,不通过对象处理,起到安全作用。

私有属性和私有方法:

总结:

1). 私有属性,可以在类内部通过self调用,但不能通过对象访问
2). 私有方法,可以在类内部通过self调用,但不能通过对象访问
3). 对象不能访问私有权限的属性和方法
4). 子类不能继承父类私有权限的属性和方法
5). Python中没有像C++中 public 和 private , protected 这些关键字来区别公有属性和私有属性。
6). Python是以属性命名方式来区分,如果在属性和方法名前面加了2个下划线'__',则表明该属性和方法是私有权限,否则为公有权限。
修改私有属性的值: 

总结:
 现代软件开发中,通常会定义get_xxx()方法和set_xxx()方法来获取和修改私有属性值
get_xxx()方法-->返回私有属性的值
set_xxx()方法-->接收参数,修改私有属性的值
对象不能访问私有权限的属性和方法,可以通过访问公有方法set_money()来修改私有属性的值,可以通过访问公有方法get_money()来获取私有属性的值
类属性和实例属性 :

 类属性和实例属性
 在了解了类基本的东西之后,下面看一下python中这几个概念的区别

先来谈一下类属性和实例属性
 
 在前面的例子中我们接触到的就是实例属性(实例对象属性),顾名思义,类属性就是类对象所拥有的属性,它被所有类对象的实例对象所共有,在内存中只存在一个副本,这个和C++中类的静态成员变量有点类似。对于公有的类属性,可以通过类或者实例对象访问 
实例属性只能通过对象来调用,类不能调用
__new__方法

总结:

1). __new__至少要有一个参数cls,代表要实例化的类,此参数在实例化时由Python解释器自动提供

2). __new__必须要有返回值,返回实例化出来的实例,这点在自己实现__new__时要特别注意,可以return父类__new__出来的实例,或者直接是object的__new__出来的实例

3). __init__有一个参数self,就是这个__new__返回的实例,__init__在__new__的基础上可以完成一些其它初始化的动作,__init__不需要返回值

4). 我们可以将类比作制造商,__new__方法就是前期的原材料购买环节,__init__方法就是在有原材料的基础上,加工,初始化商品环节

单例模式:

• 单例模式:永远用一个对象得实例,避免新建太多实例浪费资源 
• 实质:使用 __new__ 方法新建类对象时先判断是否已经建立过,如果建过就使用已有的对象 

#Demo
#私有属性和私有方法
#私有方法
class Person(object):
    def __init__(self,name,score):
        self.name=name
        self.__score=score
    def _primenthod(self):
        print("私有方法")
p=Person("qmx",18)
print(p.name)
# 调用私有方法
print(p._primenthod)
#私有属性
class Person(object):
    def __init__(self,name,score):
        self.name=name
        self.__score=score
p=Person("qmx",18)
print(p.name)
# 调用私有属性
print(p.__score)
 
#类部调用私有属性和私有方法
class Person(object):
    def __init__(self,name,score):
        self.name=name
        self.__score=score
    def __primethod(self):
        print("私有方法")
    def method(self):
        return self.__score
    def method1(self):
        return self.__primethod()
p=Person("qmx",18)
print(p.method())
p.method1()
 
#子类不能继承父类私有属性和方法
#属性
class Father(object):
    def __init__(self,name):
        self.name=name
        self.__age=18
    def eat(self):
        print("吃东西")
    def __PlayPingPang(self):
        print("喜欢玩乒乓球")
class Son(Father):
    pass
son=Son("张三")
print(son.name)
print(son.__age)
#方法
class Father(object):
    def __init__(self,name):
        self.name=name
        self.__age=18
    def eat(self):
        print("吃东西")
    def __Playpingpang(self):
        print("喜欢玩乒乓球")
class Son(Father):
    pass
son=Son("qqq")
son.eat()
son.__Playpingpang()
 
#修改私有属性的值
class People(object):
    def __init__(self):
        self.__money=1000
    def set_money(self,money):
        self.__money=money
    def get_money(self):
        return self.__money
p=People()
p.set_money(2000)
print(p.get_money())
 
#实例属性(对象属性)
class People(object):
    address="山东"
    def __init__(self):
        self.name="qqq"
        self.age=18
p=People()
p.age=12
print(p.address)
print(p.name)
print(p.age)
print(People.address)
 
#实例对象不能修改类属性
class People(object):
    counttry="中国"
print(People.counttry)
p=People()
print(p.counttry)
p.counttry="英国"
print

# 实例对象不能修改类属性
class People(object):
    counttry="中国"
print(People.counttry)
p=People()
print(p.counttry)
p.counttry="英国"
print(p.counttry)
p2=People()
print(p2.counttry)
 
# 类方法
class People(object):
    # 类属性
    age=18
    # 类方法,用classmethod来进行修饰
    @classmethod
    def get_country(cls):
        return cls.age
p=People()
# 可以用过实例对象引用
print(p.get_country())
# 可以通过类对象引用
print(People.get_country())
 
# 静态方法
class People(object):
    country="中国"
    @staticmethod
    # 静态方法
    def get_country():
        return People.country
p=People()
# 通过对象访问静态方法
print(p.get_country())
# 通过类访问静态方法
print(People.get_country())
 
# 实例方法
class People(object):
    def selfmethod(self):
        print("我是实例方法")
p=People()
p.selfmethod()
People.selfmethod()
 
# __new__方法
class A(object):
    def __init__(self):
        print("这是init方法")
    def __new__(cls):
        print("这是new方法")
        return object.__new__(cls)
a=A()
 
# 单例模式
class Foo(object):
    instance=None
    def __init__(self):
        self.name="中国"
    def __new__(cls):
        if Foo.instance:
            return Foo.instance
        else:
            Foo.instance=object.__new__(cls)
            return Foo.instance
obj1=Foo()
obj2=Foo()
print(obj1,obj2)

class numer(object):
    #类属性
    age=14
    #类方法,用classmethod来进行修饰
    @classmethod
    def get_country(cls):
        return cls.age
    #静态方法  staticmethod
    @staticmethod
    def get_country(cls):
        return cls.age@classmethod
    def get_country(cls):
        return cls.age
n=numer()
print(n.get_country())#可以通过是咧对象引用
print(numer.get_country())#通过类目


# . 创建一个老师类
# 老师类中有学习的方法
# 老师类中有私有的挣钱的方法,老师类中有私有类属性money = 100000,还有一个公有的类属性age=45
# 创建一个学生类,继承自老师类,并重写了老师类中学习的方法
# 调用学生类中挣钱的方法
# 调用老师类中的私有属性
# 修改老师类中的私有属性为200000
# 调用老师类的私有方法
# 修改类属性(分别影响某一个对象,类)
 
class teacher(object):
    #共有的类
    age = 45
    def __init__(self):
        self.__money=10000
    def study(self):
        print("我是学习方法")
    def __zhengqian(self):
        print("我是挣钱的方法")
    def set_money(self,money):
        self.__money=money
    def get_money(self):
        return  self.__money
    def fun1(self):
        print(self.__money)
    def fun2(self):
        self.__zhengqian()
#继承老师类的学生类
class student(teacher):
    def study(self):
        print("我是学习方法")
a=teacher()
b=student()
b.study()
b.fun1()
b.fun2()
a.set_money(20000) #修改
print(a.get_money())
a.age=200
print(a.age)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值