对象(object)
硬盘把数据交给内存,内存交给cpu ——>cpu强,内存大
- python是面向对象的编程语言
- 对象是内存中存储数据的区域
- 对象结构:
- id(标识)
- type(类型)
- value(值)
- 面向过程
- 将程序的逻辑分解成一个个的步骤;
- 这种编写方式往往只适用于一个功能,如果要实现别的功能,往往复用性比较低;
- 符合人类思维逻辑,编写简单。
面向对象的编程关注的是对象,而不注重过程。将所有的功能保存到对应的对象中,要使用某个功能,直接找到对应的对象即可。
这种编码方式比较容易阅读,并且易于维护,容易复用。但是编写的过程中不太符合常规的思维,编写相对麻烦
类(class)
简介
- 我们目前学习的都是Python的内置对象,但是内置对象并不都能满足我们的需求,所以我们在开发中经常要自定义一些对象
- 类相当于一张图纸,在程序汇总我们需要根据类来创建对象。类就是对象的图纸
- a = 10——>创建了一个int实例。我们也称对象是类的实例(instance)
- 如果多个对象是通过一个类创建的,我们称这些对象是一类对象
语法:
class 类名([xxx]):
pass
def MyClass():#类名
pass
# print(MyClass) <class'_ main_ . MyClass'>
#使用MyClass来创建一个对象
mc = MyClass() #mc是MyClass的实例
print (mc,type(mc))
isinstance() #判断一个对象是否是一个类的实例,返回true / false
类的定义
对现实生活中事物的抽象
由数据(属性)和行为(方法)两部分组成
• 调用方法 对象.方法名()
• 方便调用和函数调用的区别:如果是函数调用,调用时有几个形参,就会传递几个实参。如果是方法调用,默认传递一个参数,所以方法中至少得有一个形参
• 在类代码块中,我们可以定义变量和函数
• 变量会成为该类实例的公共属性,所有的该实例都可以通过 对象.属性名的形式访问
• 函数会成为该类实例的公共方法,所有该类实例都可以通过 对象.方法名的形式访问
类的说明
类也是一个对象
- 用来创建对象的对象
- 类是type类型的对象,定义类就是定义了一个type类型的对象
可以向对象中添加变量,对象中的变量称为属性
语法:
对象.属性名 = 属性值
类的属性
调用方法:对象.方法名
所有该类的实例都可以通过上面方法调用
class MyClass:
def speak(a):#方法里默认有一个形参
print(‘xxxx’)
c1 = MyClass()
c1.speak()#这里不能加参数
调用方法时,默认传递一个形参,所以定义的时候至少得有一个形参。
参数
属性和方法
- 属性和方法的查找流程
- 当我们调用一个对象的属性时,解析器会现在当前的对象中寻找是否还有该属性,如果有,则直接返回当前的对象的属性值。如果没有,则去当前对象的类对象中去寻找,如果有则返回类对象的属性值。如果没有就报错
- 类对象和实例对象中都可以保存属性(方法)
- 如果这个属性(方法)是所以的实例共享的,则应该将其保存到类对象中
- 如果这个属性(方法)是某个实例独有的。则应该保存到实例对象中
- 一般情况下,属性保存到实例对象中 而方法需要保存到类对象中
self参数
- self在定义时需要定义,但是在调用时会自动传入。
- self的名字并不是规定死的,但是最好还是按照约定是用self
- self总是指调用时的类的实例
class MyClass():
def speak(a):# 方法每次被调用,解析器会自动传递一个实参。谁调用,a就是谁。一般把这个参数命名为self
print('hello,%s'%a.name)
mc1 = MyClass()
mc2 = MyClass()
mc1.name = "name1"
mc2.name = "name2"
需求,调用mc1打印出name+speak
class People():
def speak(self):# 方法每次被调用,解析器会自动传递一个实参。谁调用,a就是谁。一般把这个参数命名为self
print('hello,%s'%self.name)
# print(self)
mc1 = People()
mc2 = People()
mc1.name = "name1"
mc2.name = "name2"
# print(mc1)