python封装 继承 多态 方法重写 object类 特殊方法和特殊属性

1、封装

面向对象的三大特征
(1)封装:提高程序的安全性
<1>将数据(属性)和行为(方法)包装到类对象中。在方法内部对属性进行操作,在类对象的外部调用方法。这样,无需关心方法内部的具体实现细节,从而隔离了复杂度。
<2>在Python中没有专门的修饰符用于属性的私有,如果该属性不希望在类对象外部被访问,前边使用两个“-”。
(3)多态:提高程序的可扩展性和可维护性

2、继承:提高代码的复用性

<1>语法格式
class 字类类名(父类1,父类2…):
pass
<2>如果一个类没有继承任何类,则默认继承object
<3>python支持继承
<4>定义字类时,必须在其构造函数中调用父类的构造函数

#坚持好好学习
class Person(object):# Person继承object类
    def __init__(self):
        self.name = name
        self.age =age
    def info(self):
        print(self.name,self.age)

class Student(Person):
    def __init__(self,name,age,stu_no):
        super().__init__(name,age)
        self.stu_no=stu_no

class Teacher(Person):
    def __init__(self,name,age,teachofyear):
        super().__init__(name,age)
        self.teachofyear=teachofyear

stu=Student('张三',10,'1010')
teacher=Teacher('李四',18,34)

stu.info()
teacher.info()

多态:提高程序的可扩展性和可维护性

1、简单地说,多态就是“具有多种形态”,它指的是:即便不知道一个变量所引用的对象到底是什么类型,仍然可以通过这个变量调用的方法,在运行过程中根据变量所引用对象的类型,动态决定调用哪个对象中的方法。
2、静态语言和动态语言关于多态的区别
静态语言实现多态的三个必要条件,继承,封装,父类引用指向字类对象

方法重写

(1)如果字类对继承自父类的某个属性或方法不满意,可以在字类中对其(方法体)进行重新编写
(2)字类重写后的方法可以通过super(),xxx()调用父类中被重写的方法

object类

(1)object类是所有类的父类,因此所有类都有object类的属性和方法。
(2)内置函数dir()可以查看指定对象所有的属性
(3)object有一个__str__()方法,用于返回一个“对象的描述”,对应于内置函数str()经常用于print()方法,帮我们查看对象的信息,所以我们经常会对__str()__进行重写

#坚持好好学习
class Srudent:
    def __init__(self,name,age):
        self.name=name
        self.age=age
    def __str__(self):
        return '我的名字是{0},今年{1}岁'.format(self.name,self.age)
stu=Srudent('张三',20)
print(dir(stu))#我的名字是张三,今年20岁
print(stu)#默认调用__str__方法
print(type(stu))
'''
['__class__', '__delattr__', '__dict__', '__dir__', '__doc__', '__eq__',
 '__format__', '__ge__', '__getattribute__', '__gt__', '__hash__', '__init__',
  '__init_subclass__', '__le__', '__lt__', '__module__', '__ne__', '__new__',
   '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__',
    '__str__', '__subclasshook__', '__weakref__']
'''

print(stu)#<__main__.Srudent object at 0x000002C585876668>

特殊方法和特殊属性

在这里插入图片描述

#坚持好好学习
#查看属性和方法
'''print(dir(object))'''

class A:
    pass
class B:
    pass
class C(A,B):
    def __init__(self,name):
        self.name =name
class D(A):
    pass
#创建C类的对象
x=C('lisa')# x是C类型的一个实例对象
print(x.__dict__)#{'name': 'lisa'} #实例对象的属性字典
print(C.__dict__)#{'__module__': '__main__', '__init__': <function C.__init__ at 0x00000211BA0B9620>, '__doc__': None}
print(('---------------------'))
print(x.__class__)#输出了对象所属的类
print(C.__bases__)#C类的父类类型的元组 (<class '__main__.A'>, <class '__main__.B'>)
print(C.__base__)#<class '__main__.A'>
print(C.mro())#类的层次结构
print(A.__subclasscheck__())

#坚持好好学习
a=10
b=20
c=a+b  #两个整数类型的对象的相加结果
d=a.__add__(b)
print(c)
print(d)

class Student:
    def __init__(self,name):
        self.name=name
    def __add__(self, other):
        return self.name+other.name
    def __len__(self):
        return  len(self.name)

stu1=Student('张三')
stu2=Student('李四')

s=stu2+stu1#s实现了两个对象的加法运算(因为在Student类中,编写__add__()特殊的方法
print(s)
s=stu1.__add__(stu2)
print(s)
print('----------------------')

lst=[12,3,44,55]
print(len(lst))#lem是内容函数len
print(lst.__len__())
print(len(stu1))
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值