Python 面向对象

本文介绍了Python中的面向对象编程,包括类、对象、数据封装、继承、多态等概念。阐述了面向对象技术的基本特点,如类与对象的关系、方法重写、实例变量与局部变量的区别,并通过实例展示了面向对象编程的应用。同时讨论了面向过程和面向对象的优缺点,以及Python中的私有属性和封装原则。
摘要由CSDN通过智能技术生成

面向对象

  • 面向过程
  • 函数式编程
  • 面向对象

面向对象技术简介

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

和其它编程语言相比,Python 在尽可能不增加新的语法和语义的情况下加入了类机制。

Python中的类提供了面向对象编程的所有基本功能:类的继承机制允许多个基类,派生类可以覆盖基类中的任何方法,方法中可以调用基类中的同名方法。

对象可以包含任意数量和类型的数据。

面向过程

所谓过程就是我们解决问题的步骤,一步步的按照流程走,有先后之分

设计好比流水线,思维上比较机械化

优缺点:

  • 优点
    • 复杂的问题流程化,将问题分解简化
  • 缺点
    • 拓展性不足

面向对象

核心是对象

  • 对象是一个数据以及相关行为的集合
  • 面向对象是功能上指向建模对象

通过数据和行为方式来描述交互对象的集合

在python中,一切皆为对象

面向对象的优缺点

  • 优点
    • 解决程序的拓展性
  • 缺点
    • 就是复杂度远高于面向过程
    • 交互式解决问题,无法准确预测结果

现实中

object1:   #对象1
  Tom
  
     特征:
    school=zucc
    name=Tom
    age=20
    sex=male
    
    技能:
    eat
    study
    sleep
    
object2:
  Jack
    特征:
    school=zucc
    name=Jack
    age=21
    sex=male
    
    技能:
    eat
    study
    sleep
    sing
     

类就是类别、种类

对象就是特征和技能的统一体

类则是这一系列对象的特征和技能的结合

现实中,现有个体(即对象),才有类别,但对于程序,现有类,才有对象

面向对象编程

OOP(object oriented programming)

其实就是一种程序设计思想。OOP把对象作为程序的一个基本单元,一个对象就包含了数据和操作数据的函数

在python中,所有数据类型都可以视为对象,同时,我们也可以自定义对象

  • 自定义的对象数据类型就是面向对象中类(class)的概念

Demo:

假如要处理我们的成绩,为了表示学生的成绩:

  • 面向过程的方式
stu1 = {
   'name':'Tom','score':'99'}
stu2 = {
   'name':'Jack','score':'90'}

利用函数来实现

def find_score(stu):
  print(stu['name'],':',stu['score'])

  

利用类来实现

class Student:
    def __init__(self,school,name,age,sex):
        self.school = school
        self.name = name
        self.age = age
        self.sex = sex

    def eat(self):
        print(self.name,'is eating.')

    def study(self):
        print(self.name,'is studying')

    def sleep(self):
        print(self.name,'is sleeping')

stu1 = Student('ZUCC','tom',22,'男')
stu1.eat()



Tom : 99
tom is eating.

面向对象设计思想,先抽象出类,再根据类创建实例

class Classname(object):
  """docstring"""
  class_statement

创建一个类,大驼峰式(就是变量名称的单词首字母大写)

class Myfirstclass:
  pass

类的作用是一个模版,我们可以在创建实例的时候,把一些 必须要绑定的属性填写进去,这时就通过特殊的__init__方法,在创建实例的时候,绑定相关的属性,比如前面的name,score.

class Student:
    school = 'ZUCC'

    def __init__(self, name, score):
        self.name = name
        self.score = score


stu1 = Student('Tom', 99) #实例化
print((stu1.name, stu1.score, stu1.school))


('Tom', 99, 'ZUCC')

和普通函数相比,在类中定义方法时,第一个参数必须是self,除第一个参数外,其他和普通参数没有什么区别

Self 代表的是实例,而非类

__init__方法

  • 为对象初始化自己独有的特征
  • 该方法中可以有任意的代码,但一定不可以是返回值

数据封装

class Student:

    def __init__(self, name, score):
        self.name = name
        self.score = score

    def find_score(self): #封装
        print(self.name, ':', self.score)


stu1 = Student('Tom', 99)
stu1.find_score()


Tom : 99

我们通过__init__()让stu1实例本身就拥有了相关数据,如果要访问这些数据,我们可以直接在student类的内部定义相关的函数 来访问数据,以此封装数据

这些封装数据的函数和student类本身是关联起来的,他们被称之为方法

class point:
    pass


p1 = point()
p2 = point()

p1
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值