课上笔记(五)(Python)
- 学习使我快乐
面向对象程序设计
- 封装,继承,多态,覆盖,重写
类定义
class Hello:
class是定义类的关键字
Hello是类名,简易一般首字母大写
类定义可以用来实例化对象
简单来说就是类可以通过实例化来将类变成一个对象
输入:
class Car:
def info(self):
print('this is a car')
if __name__=='__main__':
car = Car()
car.info()
输出:
this is a car
然而实际上就算不进行实例化,也是可以达到同样效果。
但是在运行之后我遇到了问题,
即:括号里面需要实参(哪怕根本不需要实参)
输入:
class Car:
def info(self):
print('this is a car')
if __name__=='__main__':
Car.info(1)
输出:
this is a car
输入:
class Car:
def info(self):
print('this is a car')
if __name__=='__main__':
Car.info()
输出:
TypeError: info() missing 1 required positional argument: 'self'
类成员和实例成员
- 类成员是在 类 下面的变量(可以视为在类中的全局变量)←—在类之外也可以使用
- 实例成员是在类之下的 构造函数 下面的变量(用self.做前缀)←—只能在类内使用
构造函数
假如你构造了一个类,而在这个类下面有一个
def __init__(self):
这就是构造函数。
- 构造函数和正常的函数没有区别
- 如果你实例化构造函数,那么构造函数会强行运行一次
- 在定义构造函数下的变量(即:实例变量(用self.做前缀))时,需要在该变量前加上
self.
输入:
class Abc:
def __init__(self, ab):
self.a = ab
if __name__ == '__main__':
abc = Abc(5)
print(abc.a)
输出:
5
在类进行实例化时,类之后需要有参数,否则会报错
输入:
class Abc:
def __init__(self, ab):
self.a = ab
if __name__ == '__main__':
abc = Abc()
print(abc.a)
输出:
TypeError: __init__() missing 1 required positional argument: 'a'
构造函数下所定义的实例变量可以在该类中所有方法中正常使用
私有成员与公有成员
——正常来说,这是一种访问保护机制,只是python对这个东西并不是很严格。
在定义累的属性时,在属性前面增加“__”两个下划线,则表示其为一种私有属性
即:不能在类之外,查看该变量是什么