python-面向过程、面向对象、类

面向过程编程

前言:编程不就编程吗?怎么还有这么多的洋气词后缀??今天主要介绍一下面向过程和面向对象是什么。

大白话版本:面向过程编程可以比作是做一道菜,那么做一道菜分为几步呢??

  1. 准备食材
  2. 起锅烧油
  3. 放辅料
  4. 炒菜
  5. 出锅

最高端的食材往往只需要最简单的烹饪方式,呸,撤回来昂。这个过程,分布来,按部就班的,一步一步的过程为面向过程。

如果还不理解的话,那么想一想,把大象装进冰箱需要几步?,显然是三步了,打开冰箱把大象塞进去,关上冰箱!

  • 面向过程编程其实也是一样的,将编程要实现的目标,按步骤实现,每一步就是一个过程!

实例一:

# 做菜的步骤,通过面向过程编程实现
def step1():
print('第一步,准备食材')
def step2():
print('第二步,起锅烧油')
def step3():
print('第一步,放辅料')
def step4():
print('第一步,炒菜')
def step5():
print('第一步,出锅') def mainstep():
step1()
step2()
step3()
step4()
step5()
print('感谢老板祝老板生八个儿子') mainstep() #结果
第一步,准备食材
第二步,起锅烧油
第一步,放辅料
第一步,炒菜
第一步,出锅
感谢老板祝老板生八个儿子

实例二:

# 用户注册功能
'''
1.获取用户名和密码
2.组织成固定的格式
3.文件操作写入文件
''' # 定义获取用户信息函数
def get_info():
username = input('please input your name>>>:').strip()
pwd = input('please input your pwd>>>:').strip()
if len(username) == 0 or len(pwd) == 0:
print('your username or name is empty,please try again!')
return
else:
user_id = {
'1': 'admin',
'2': 'user'
}
print(user_id)
choice = input('please choice your position:')
if choice == '1':
id = user_id[choice]
print('you are admin!')
elif choice == '2':
id = user_id[choice]
print('you are user!')
return make_info(username, pwd, id) # 处理信息格式
def make_info(username, pwd, id):
data = f'{username}|{pwd}|{id}\n'
return save_info(data) # 存储到文件
def save_info(data):
with open(r'user_info.txt', 'a', encoding='utf8') as f:
f.write(data)
print('sign success!') # 调用主体函数
get_info() # 结果
please input your name>>>:hammer
please input your pwd>>>:123
{'1': 'admin', '2': 'user'}
please choice your position:1
you are admin!
sign success!

牛逼定义:面向过程的程序设计把计算机程序视为一系列的命令集合,即一组函数的顺序执行。为了简化程序设计,面向过程把函数继续切分为子函数,即把大块函数通过切割成小块函数来降低系统的复杂度


面向对象

前言:面向对象,此对象非彼对象,面向对象的核心在于“对象”二字。

大白话版本:面向对象可以理解为,做菜的过程我们创造了一个机器人,把食材准备好和步骤写入机器人,那么可以理解为食材是我们需要的“数据”,如何做菜的步骤理解为“功能”,这个就是面向对象,总的来说就是定义出一系列的功能来对数据进行操作

  • 程序中对象:对象是把数据和功能整合到一起的产物,或对象就是盛放数据与功能的容器
  • 现实生活中:对象就是特征和技能的结合体

示例如下:

# 未学习面向对象前,所有数据和功能都是散开的
# 数据
name = 'HammerZe'
course = []
# 功能
def add_course(name,course):
course.append('python')
print(f"学生{name}选课{course}")
add_course(name,course) # 结果
学生HammerZe选课['python']

这样我们发现,如果有100个学生需要和格式化输出结果怎么办?写100次吗?是不是非常的麻烦

# 升级版
def add_course(user_info,course):
user_info['course'].append(course)
print(f"学生{user_info['name']}选课{user_info['course']}") user_info = {
'name': 'HammerZe',
'course':[],
'add_course':add_course,
} user_info['add_course'](user_info,'python')
# 结果
学生HammerZe选课['python']
'''通过整合,把数据和功能写在一起,结果是一样的'''

类和对象

二者区别

  • 生活中

    • 对象:特征与技能的结合体

    • 类:具有相似的特征,相似的技能归为一类,

    • 例如:西瓜和哈密瓜可以归为一水果类,

      狗和猫可以归为动物一类·····

    • 强调:站在不同的分类角度,划分的类可能不一样,是先有对象,才有类的

  • 程序中:

    • 对象:数据和功能的结合体
    • 类:具有相似数据,相似功能 的为一类
    • 强调:必须先定义类,再调用类产生对象

定义格式:

  1. 定义函数

    def 函数名():

    pass

  2. 定义类:

    class 类名():

    pass

    类比两者记忆

定义类发生的事情

  1. 立即执行类内代码
  2. 产生一个类的名称空间,把类内执行的名字都丢到名称空间中(丢到大字典中)
  3. 把类的名称空间绑定给__ dict __,类名 . __dict__查看名称空间

示例如下:

class Student():
def add_course(user_info, course):
user_info['course'].append(course)
print(f"学生{user_info['name']}选课{user_info['course']}")
print('调用类就会执行我!!') # 查看类的名称空间
print(Student.__dict__) # 产生对象:调用类的时候产生一个空对象{}
stu1 = Student() # 查看对象的名称空间
print(stu1.__dict__) # {}

定义类的标准格式

用学生类举例

class Student():
# 初始化
def __init__(self,name,age):
self.name = name # stu.__dict__['name'] = 'Hammer'
self.age = age '''注意:return 在这个方法中不能有返回值''' # 选课方法
def choose_course(stu_dict,course):
stu_dict['course'].append(course)
print(f"学生{stu_dict['name']}选课{course}") stu = Student('HammerZe',18)
'''1.调用类产生一个空对象
2.调用了Student.__dict__(空对象,'HmmerZe',18)''' # 查看类的名称空间
print(Student.__dict__)
# 查看对象的名称空间
print(stu.__dict__)# {'name': 'HammerZe', 'age': 18}
# 取值
print(stu.__dict__['name'])
print(stu.name)

属性的查找顺序

  • 属性的查找:

    • 类属性:在类中的属性就称为类属性
    • 对象属性:在对象自己的名称空间中属性就是对象属性
    • 注意:
      • 属性的查找:先从自己的对象中查找,然后在去产生对象的类中取找

        如果使用dict从对象的名称空间获取值,找不到会报错

        使用.获取值,在自己的名称空间找不到会取类的名称空间查找

示例如下

class Student():
# 初始化
school = 'SH' def __init__(self, name, age,course = None):
if course is None:
course = []
self.name = name # stu.__dict__['name'] = 'Hammer'
self.age = age
self.course = course '''注意:return 在这个方法中不能有返回值''' # 选课方法
def choose_course(self, course):
self.course.append(course)
print(f"学生{self.name}选课{self.course}") stu = Student('HammerZe', 18)
'''1.调用类产生一个空对象
2.调用了Student.__dict__(空对象,'HmmerZe',18)''' ''' 属性的查找:先从自己的对象中查找,然后在去产生对象的类中取找
如果使用__dict__从对象的名称空间获取值,找不到会报错
使用.获取值,在自己的名称空间找不到会取类的名称空间查找
'''
# 类的查找
# 查看名称空间
print(Student.__dict__)
# 查看值
print(Student.school) # SH
# 查看方法
print(Student.choose_course)
# 类的增加
Student.country = 'China'
print(Student.__dict__['country']) # China
# 类的修改
Student.school = 'BJ'
print(Student.__dict__['school']) # BJ
# 类的删除
del Student.school
print(Student.__dict__.get('school')) # None
''' 底层为字典可以用get ''' # 对象的增删查改
# 查看名称空间
print(stu.__dict__) # {'name': 'HammerZe', 'age': 18}
# 查看值
print(stu.name) # HammerZe # 修改值
stu.name = 'Ze'
print(stu.name) # Ze # 增加值
stu.gender = 'male'
print(stu.__dict__) # {'name': 'Ze', 'age': 18, 'gender': 'male'} # 删除值
del stu.gender
print(stu.__dict__) # {'name': 'Ze', 'age': 18} # 方法的调用
# 类调用
Student.choose_course(stu,'python') # 学生Ze选课['python']
# 对象调用
stu.choose_course('java') # 学生Ze选课['python', 'java']
  • 注意:类中的方法,类可以调用,对象也可以调用, 但是,推荐对象来调用,因为对象来调用,会把自己当成第一个参数传递给函数

python-面向过程、面向对象、类的更多相关文章

  1. Python面向过程、模块的使用

    一.Python面向过程 ''' 面向过程编程 核心过程二字,过程指的是解决问题的步骤,即先干什么.再干什么.然后干什么... 基于该思想编写程序就好比在设计一条流水线,是一种机械式的思维方式 优点 ...

  2. php连接数据库的两种方式- 面向过程 面向对象

    php连接数据库的两种方式- 面向过程 面向对象   一.面向对象1. 链接数据库$conn = @new mysqli("127.0.0.1","root", ...

  3. JavaSE——面向对象与面向过程、类与对象、(属性、方法、构造器)等

    一:面向对象与面向过程 二者都是一种思想,面向对象是相对于面向过程而言的. 面向过程: 1.面向过程思想强调的是过程(动作). 2.在面向过程的开发中,其实就是面向着具体的每一个步骤和过程,把每一个步 ...

  4. Python面向过程和面向对象基础

    总结一下: 面向过程编程:根据业务逻辑从上到下的写代码-----就是一个project写到底,重复利用性比较差 函数式:将某些特定功能代码封装到函数中------方便日后调用 面向对象:对函数进行分类 ...

  5. python 面向过程和面向对象比较

    面向过程 VS 面向对象 面向过程的程序设计:核心是过程二字,过程指的是解决问题的步骤,即先干什么再干什么......面向过程的设计就好比精心设计好一条流水线,是一种机械式的思维方式. 优点是:复杂度 ...

  6. 面向过程—面向对象(C++的封装,this)_内存四区_变量生命周期

    1.面向对象主要涉及  构造函数.析构函数.虚函数.继承.多态等. 2.对各种支持 的底层实现机制 c语言中,数据 和 处理数据的操作(函数) 是分开来声明,即语言本身并没有支持 “数据和函数”的关联 ...

  7. 2017 5 31 php面向过程 面向对象1

    面向过程的语法定义变量:定义函数:使用变量(输出,赋值,等)调用函数:流程控制(if,switch,for,while等) 面向对象的语法1,定义类:定义类的语法中,只有这3种代码:1.1定义属性(变 ...

  8. 【java基础】面向过程~面向对象

    相信大家都知道这两个东西,可是大家是如何知道的呢?我们又该如何区分这个东西到底是面向过程还是面向对象的呢? 那,我们首先就要知道什么是面向过程,什么是面向对象: 面向过程"(Procedur ...

  9. python(五):面向对象--类和实例

    一.类的基本概念 类是用来创建数据结构和新类型对象的主要机制.一个类定义了一系列与其实例对象密切关联的属性.典型的属性包括变量(也被称为 类变量)和函数(又被称为方法). 1.class上下文 cla ...

  10. python面向编程;类的绑定与非绑定方法、反射、内置方法

    一.类的绑定与非绑定方法 ''' 类中定义函数分为了两大类: 1. 绑定方法 特殊之处: 绑定给谁就应该由谁来调用,谁来调用就会将谁当做第一个参数自动传入 绑定给对象的方法: 在类中定义函数没有被任何 ...

随机推荐

  1. 兜底机制——leader到底做了什么?

    Case 在之前一次年底考评的时候,有一位leader将一个案例同时用到了自己和下属身上,老板发出了责问: 这个项目到底你是负责人,还是你下面的同学是负责人,如果下面的同学是负责人,为什么要算到你的头 ...

  2. 【死磕 NIO】— Reactor 模式就一定意味着高性能吗?

    大家好,我是大明哥,我又来了. 为什么是 Reactor 一般所有的网络服务,一般分为如下几个步骤: 读请求(read request) 读解析(read decode) 处理程序(process s ...

  3. 【UE4】基础概念——文件结构、类型、反射、编译、接口、垃圾回收、序列化

    新标签打开或者下载看大图 思维导图 Engine Structure Pipeline Programming Pipeline Blueprint Pipeline

  4. 【Linux命令063】Linux非常简单常用的入门命令

    Linux常用命令 这是一篇我在公众号上发布的文章,还算较为受欢迎. 博客园这边荒废好长时间了,主要是最近一年经常撰写的文章都是Linux相关的入门文章. 不知道是否能通过博客园的首页审核. 1.cd ...

  5. 四万字32图,Kafka知识体系保姆级教程宝典

    本文目录: 一.消息队列 Apache Pulsar Pulsar 与 Kafka 对比 二.Kafka基础 三.Kafka架构及组件 四.Kafka集群操作 五.Kafka的JavaAPI操作 六. ...

  6. react 生命周期 个人见解

    初始化/实例期 gitDefaultprops 获取组件的默认props状态 gitInitialstate 类定义方式或是直接在构造函数中挂载state componentWillMount  组件 ...

  7. Pogo-Cow S

    这题出在单调队列优化dp里,就离谱好吧...... 对不住了上来先喷一波,不过离谱是确实的 dp的含义也很简单,就是说从j到i的分数最大值 直接上代马,里面说的很详细了 1 #include<b ...

  8. pku 2425 A Chess Game (SG)

    题意: 给一个由N个点组成的一张有向图,不存在环.点的编号是0~N-1. 然后给出M个棋子所在的位置(点的编号)[一个点上可同时有多个棋子]. 每人每次可移动M个棋子中的一个棋子一步,移动方向是有向边 ...

  9. Jmeter 踩坑记录(七)

    1.master连不上Slave机 解决方法:telnet 192.168.xx.xx 1099  看IP 端口通不通,如果通 OK,不通,检查关闭防火墙或者开放端口 2.salve 连不上 mast ...

  10. 设计模式二--模板方法Template method

    模式分类: 书籍推荐:重构-改善既有代码的设计 重构获得模式 设计模式:现代软件设计的特征是"需求的频繁变化".设计模式的要点是 "寻找变化点,然后在变化点处应用设计模式 ...