ad09只在一定范围内查找相似对象_23、面向对象编程

目录:

  • 对象的概念
  • 类与对象
  • 面向对象编程
    • 类的定义与实例化
    • 属性访问
      • 类属性与对象属性
      • 属性查找顺序与绑定方法
      • 小结
  • 视频链接

一 对象的概念

68ca40764fbe79d6ad65c6f859e3715d.png

”面向对象“的核心是“对象”二字,而对象的精髓在于“整合“,什么意思?

ec1df3c5edaff3b8dc1442e8e5256b42.png

所有的程序都是由”数据”与“功能“组成,因而编写程序的本质就是定义出一系列的数据,然后定义出一系列的功能来对数据进行操作。在学习”对象“之前,程序中的数据与功能是分离开的,如下

# 数据:name、age、sex
name='lili'
age=18
sex='female'# 功能:tell_info
def tell_info(name,age,sex): print('<%s:%s:%s>' %(name,age,sex))# 此时若想执行查看个人信息的功能,需要同时拿来两样东西,一类是功能tell_info,另外一类则是多个数据name、age、sex,然后才能执行,非常麻烦
tell_info(name,age,sex)

在学习了“对象”之后,我们就有了一个容器,该容器可以盛放数据与功能,所以我们可以说:对象是把数据与功能整合到一起的产物,或者说”对象“就是一个盛放数据与功能的容器/箱子/盒子。

如果把”数据“比喻为”睫毛膏“、”眼影“、”唇彩“等化妆所需要的原材料;把”功能“比喻为眼线笔、眉笔等化妆所需要的工具,那么”对象“就是一个彩妆盒,彩妆盒可以把”原材料“与”工具“都装到一起

f4174709a5dff895552daf5974b5cfbe.png

如果我们把”化妆“比喻为要执行的业务逻辑,此时只需要拿来一样东西即可,那就是彩妆盒,因为彩妆盒里整合了化妆所需的所有原材料与功能,这比起你分别拿来原材料与功能才能执行,要方便的多。

2614f5999f45318e7ec747209a684238.png

​ 在了解了对象的基本概念之后,理解面向对象的编程方式就相对简单很多了,面向对象编程就是要造出一个个的对象,把原本分散开的相关数据与功能整合到一个个的对象里,这么做既方便使用,也可以提高程序的解耦合程度,进而提升了程序的可扩展性(需要强调的是,软件质量属性包含很多方面,面向对象解决的仅仅只是扩展性问题)

d8bff539f702e681cc21e80125ab95bd.png

二 类与对象

类即类别/种类,是面向对象分析和设计的基石,如果多个对象有相似的数据与功能,那么该多个对象就属于同一种类。有了类的好处是:我们可以把同一类对象相同的数据与功能存放到类里,而无需每个对象都重复存一份,这样每个对象里只需存自己独有的数据即可,极大地节省了空间。所以,如果说对象是用来存放数据与功能的容器,那么类则是用来存放多个对象相同的数据与功能的容器。

044bcc985acad7275eee75b702fb6ec7.png

​ 综上所述,虽然我们是先介绍对象后介绍类,但是需要强调的是:在程序中,必须要事先定义类,然后再调用类产生对象(调用类拿到的返回值就是对象)。产生对象的类与对象之间存在关联,这种关联指的是:对象可以访问到类中共有的数据与功能,所以类中的内容仍然是属于对象的,类只不过是一种节省空间、减少代码冗余的机制,面向对象编程最终的核心仍然是去使用对象。

​ 在了解了类与对象这两大核心概念之后,我们就可以来介绍一下面向对象编程啦。

1e7c262e6bf7a12209711578e8b684e6.png

三 面向对象编程

3.1 类的定义与实例化

我们以开发一个清华大学的选课系统为例,来简单介绍基于面向对象的思想如何编写程序

f80456cf8ea9220bac8487f3ac7a8dd3.png

面向对象的基本思路就是把程序中要用到的、相关联的数据与功能整合到对象里,然后再去使用,但程序中要用到的数据以及功能那么多,如何找到相关连的呢?我需要先提取选课系统里的角色:学生、老师、课程等,然后显而易见的是:学生有学生相关的数据于功能,老师有老师相关的数据与功能,我们单以学生为例,

# 学生的数据有
学校
名字
年龄
性别# 学生的功能有
选课

详细的

# 学生1:数据:学校=清华大学姓名=李建刚性别=男年龄=28功能:选课# 学生2:数据:学校=清华大学姓名=王大力性别=女年龄=18功能:选课# 学生3:数据:学校=清华大学姓名=牛嗷嗷性别=男年龄=38功能:选课

我们可以总结出一个学生类,用来存放学生们相同的数据与功能

# 学生类相同的特征:学校=清华大学相同的功能:选课

760da8b2b4d8349e483de9e066aa4bd0.png

基于上述分析的结果,我们接下来需要做的就是在程序中定义出类,然后调用类产生对象

class Student: # 类的命名应该使用“驼峰体”school='清华大学' # 数据def choose(self): # 功能print('%s is choosing a course' %self.name)

类体最常见的是变量的定义和函数的定义,但其实类体可以包含任意Python代码,类体的代码在类定义阶段就会执行,因而会产生新的名称空间用来存放类中定义的名字,可以打印Student.__dict__来查看类这个容器内盛放的东西

>>> print(Student.__dict__)
{..., 'school': '清华大学', 'choose': <function Student.choose at 0x1018a2950>, ...}

9402511f6fe5ad3a0fd00971c8d2d85b.png

调用类的过程称为将类实例化,拿到的返回值就是程序中的对象,或称为一个实例

>>> stu1=Student() # 每实例化一次Student类就得到一个学生对象
>>> stu2=Student()
>>> stu3=Student()

如此stu1、stu2、stu3全都一样了(只有类中共有的内容,而没有各自独有的数据),想在实例化的过程中就为三位学生定制各自独有的数据:姓名,性别,年龄,需要我们在类内部新增一个__init__方法,如下

class Student:school='清华大学'#该方法会在对象产生之后自动执行,专门为对象进行初始化操作,可以有任意代码,但一定不能返回非None的值def __init__(self,name,sex,age):self.name=nameself.sex=sexself.age=agedef choose(self): print('%s is choosing a course' %self.name)

然后我们重新实例出三位学生

>>> stu1=Student('李建刚','男',28)
>>> stu2=Student('王大力','女',18)
>>> stu3=Student('牛嗷嗷','男',38)

单拿stu1的产生过程来分析,调用类会先产生一个空对象stu1,然后将stu1连同调用类时括号内的参数一起传给Student.__init__(stu1,’李建刚’,’男’,28)

def __init__(self, name, sex, age):self.name = name  # stu1.name = '李建刚'self.sex = sex    # stu1.sex = '男'self.age = age    # stu1.age = 28

会产生对象的名称空间,同样可以用__dict__查看

>>> stu1.__dict__
{'name': '李建刚', 'sex': '男', 'age': 28}

ffb6b6a21178e3a1f5507087204016aa.png

至此,我们造出了三个对象与一个类,对象存放各自独有的数据,类中存放对象们共有的内容

374bf6bde7fc80db4fea08980690be40.png

9efe96417f6d888941859c5eeab93b4f.png

存的目的是为了用,那么如何访问对象或者类中存放的内容呢?

62b65e4d85d43f2327bf0131a79d8007.png

3.2 属性访问

3.2.1 类属性与对象属性

7fe9b8bc34cb796df8b83a8b492ae76a.png

在类中定义的名字,都是类的属性,细说的话,类有两种属性:数据属性和函数属性,可以通过__dict__访问属性的值,比如Student.__dict__[‘school’],但Python提供了专门的属性访问语法

插图:恶搞图

>>> Student.school # 访问数据属性,等同于Student.__dict__['school']
'清华大学'
>>> Student.choose # 访问函数属性,等同于Student.__dict__['choose']
<function Student.choose at 0x1018a2950>
# 除了查看属性外,我们还可以使用Student.attrib=value(修改或新增属性),用del Student.attrib删除属性。

操作对象的属性也是一样

>>> stu1.name # 查看,等同于obj1.__dict__[‘name']
'李建刚'
>>> stu1.course=’python’ # 新增,等同于obj1.__dict__[‘course']='python'
>>> stu1.age=38 # 修改,等同于obj1.__dict__[‘age']=38
>>> del obj1.course # 删除,等同于del obj1.__dict__['course']

9efe96417f6d888941859c5eeab93b4f.png

3.2.2 属性查找顺序与绑定方法

对象的名称空间里只存放着对象独有的属性,而对象们相似的属性是存放于类中的。对象在访问属性时,会优先从对象本身的__dict__中查找,未找到,则去类的__dict__中查找

62b65e4d85d43f2327bf0131a79d8007.png

1、类中定义的变量是类的数据属性,是共享给所有对象用的,指向相同的内存地址

# id都一样
print(id(Student.school)) # 4301108704print(id(stu1.school)) # 4301108704
print(id(stu2.school)) # 4301108704
print(id(stu3.school)) # 4301108704

4337805126aaeb26f73802845ea900bc.png

4f58e786d0fa9d9e0edbdf001991f3bd.png

2、类中定义的函数是类的函数属性,类可以使用,但必须遵循函数的参数规则,有几个参数需要传几个参数

Student.choose(stu1) # 李建刚 is choosing a course
Student.choose(stu2) # 王大力 is choosing a course
Student.choose(stu3) # 牛嗷嗷 is choosing a course

但其实类中定义的函数主要是给对象使用的,而且是绑定给对象的,虽然所有对象指向的都是相同的功能,但是绑定到不同的对象就是不同的绑定方法,内存地址各不相同

print(id(Student.choose)) # 4335426280print(id(stu1.choose)) # 4300433608
print(id(stu2.choose)) # 4300433608
print(id(stu3.choose)) # 4300433608

绑定到对象的方法特殊之处在于,绑定给谁就应该由谁来调用,谁来调用,就会将’谁’本身当做第一个参数自动传入(方法__init__也是一样的道理)

stu1.choose()  # 等同于Student.choose(stu1)
stu2.choose()  # 等同于Student.choose(stu2)
stu3.choose()  # 等同于Student.choose(stu3)

绑定到不同对象的choose技能,虽然都是选课,但李建刚选的课,不会选给王大力,这正是”绑定“二字的精髓所在。

#注意:绑定到对象方法的这种自动传值的特征,决定了在类中定义的函数都要默认写一个参数self,self可以是任意名字,但命名为self是约定俗成的。

e2023b90890a4f639c899e2d6376d156.png

Python中一切皆为对象,且Python3中类与类型是一个概念,因而绑定方法我们早就接触过

#类型list就是类
>>> list
<class 'list'>#实例化的到3个对象l1,l2,l3
>>> l1=list([1,2,3])
>>> l2=list(['a','b','c'])
>>> l3=list(['x','y'])#三个对象都有绑定方法append,是相同的功能,但内存地址不同
>>> l1.append
<built-in method append of list object at 0x10b482b48>
>>> l2.append
<built-in method append of list object at 0x10b482b88>
>>> l3.append
<built-in method append of list object at 0x10b482bc8>#操作绑定方法l1.append(4),就是在往l1添加4,绝对不会将4添加到l2或l3
>>> l1.append(4) #等同于list.append(l1,4)
>>> l1
[1,2,3,4]
>>> l2
['a','b','c']
>>> l3
['x','y']

4337805126aaeb26f73802845ea900bc.png

3.3.3 小结

在上述介绍类与对象的使用过程中,我们更多的是站在底层原理的角度去介绍类与对象之间的关联关系,如果只是站在使用的角度,我们无需考虑语法“对象.属性"中”属性“到底源自于哪里,只需要知道是通过对象获取到的就可以了,所以说,对象是一个高度整合的产物,有了对象,我们只需要使用”对象.xxx“的语法就可以得到跟这个对象相关的所有数据与功能,十分方便且解耦合程度极高。

62b65e4d85d43f2327bf0131a79d8007.png

b8b1b30488ab30affa36bbf03cfc62ac.png

视频链接:

python快速入门(一)_哔哩哔哩 (゜-゜)つロ 干杯~-bilibili​www.bilibili.com
85515560bf7b1078778051d9cf1e25f9.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/386008.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java开发工程师转行可以做什么

前言 分布式事务主要解决分布式一致性的问题。说到底就是数据的分布式操作导致仅依靠本地事务无法保证原子性。与单机版的事务不同的是&#xff0c;单机是把多个命令打包成一个统一处理&#xff0c;分布式事务是将多个机器上执行的命令打包成一个命令统一处理。 MySQL 提供了…

atlas怎么看日志_亿级的日志治理!微服务最佳方案,ELK stack从零搭建

ELK Stack 诞生背景一般我们需要进行日志分析场景&#xff1a;直接在日志文件中 grep、awk 就可以获得自己想要的信息。但在规模较大的场景中&#xff0c;此方法效率低下&#xff0c;面临问题包括日志量太大如何归档、文本搜索太慢怎么办、如何多维度查询。需要集中化的日志管理…

java开发工程师面试问题大全及答案大全

前言 Alibaba作为国内互联网行业的“老大”&#xff0c;一直以来也是很多“数码宝贝”梦寐以求的公司&#xff0c;我个人是做Java开发的&#xff0c;阿里这些年也开发了很多屌炸天的开源项目&#xff0c;像什么Spring Cloud Alibaba&#xff0c;开源Java诊断工具Arthas&#x…

me shy是什么歌 抖音make_内含活动福利 | 小红书、抖音爆赞的高颜值的北欧家居神店开到卜蜂中心啦!...

几个月前&#xff0c;一家北欧范颜值爆表的瑞典独立设计师品牌家居店凭借其充满设计感的产品刷爆社交媒体微博、小红书、抖音经常出现它的身影随便一篇阅读量、收藏量都好几万数不清的爆like让人按耐不住了&#xff01;这个品牌叫NǑME家居(认住这个正版的Ǒ)&#xff0c;开到哪…

java开发工程师面试题及答案

前言 作为一名编程人员&#xff0c;对MySQL一定不会陌生&#xff0c;尤其是互联网行业&#xff0c;对MySQL的使用是比较多的。对于求职者来说&#xff0c;MySQL又是面试中一定会问到的重点&#xff0c;很多人拥有大厂梦&#xff0c;却因为MySQL败下阵来。实际上&#xff0c;My…

吕玉琴考研指导电子版_【干货大放送】中国历代文学作品选阅读指导PDF

跟紧我&#xff0c;来年轻松收获录取通知书~长按一战成硕hello&#xff0c;我是小致带你考研上路今天给大家分享的干货内容是《历代文学作品选》阅读指导之前1000题浓缩资料&#xff0c;后台回复【浓缩】获取不要再留邮箱了&#xff0c;直接后台获取本次资料由致远文学考研原创…

java开发工程师面试题总结

一、背景 我们日常在电商网站购物时经常会遇到一些高并发的场景&#xff0c;例如电商 App 上经常出现的秒杀活动、限量优惠券抢购&#xff0c;还有我们去哪儿网的火车票抢票系统等&#xff0c;这些场景有一个共同特点就是访问量激增&#xff0c;虽然在系统设计时会通过限流、异…

7天拿到阿里Android岗位offer,都是精髓!

食用指南 和大部分人一样&#xff0c;我在复习完第一遍Android知识的情况下&#xff0c;看到相关的知识回答的仍然不能够令自己满意。 在第二遍系统复习的时候&#xff0c;我着重记住每个知识点的关键字&#xff0c;根据这些关键字拼凑出大概的知识点&#xff0c;最后看到每个…

7天拿到阿里安卓岗位offer,统统给你解决!

开头 技术的发展产生了程序员这个职位&#xff0c;从这些年各大互联网公司曝光的一些员工收入水平来看&#xff0c;程序员的工资还是相对比较高的&#xff0c;可是我们在互联网上还听到了另外一种声音&#xff0c;很多程序员想转行&#xff0c;特别是大龄程序员&#xff0c;这…

7天拿到阿里安卓岗位offer,附高频面试题合集

前言 众所周知&#xff0c;Android是一个基于Linux实现的操作系统。但对于Linux内核来说&#xff0c;Android也仅仅只是一个运行在内核之上的应用程序&#xff0c;与其他运行在内核之上的应用程序没有任何区别。 所以Android也需要运行环境&#xff0c;需要Linux内核在启动完…

找零钱问题

最近在做华为机试体验题&#xff0c;遇到一个“找零钱”的题目&#xff0c;如下 想起之前在牛客网上看到左程云老师讲过的动态规划问题&#xff0c;很像&#xff0c;题目如下&#xff1a; 有数组penny&#xff0c;penny中所有的值都为正数且不重复。每个值代表一种面值的货币&…

vga焊接线顺序_焊接工艺问答,不做焊接也要收藏起来

点 机械前沿”关注置顶引领机械前沿、机械视频&#xff0c;汽车、加工技术、3D打印、自动化、机器人、生产工艺、轴承、模具、机床、钣金等行业前沿在这里等你 焊接工艺问答1.什么叫焊接条件&#xff1f;它有哪些内容&#xff1f; 答&#xff1a;焊…

7年老Android一次操蛋的面试经历,挥泪整理面经

看到还有很多程序员连面试流程都没有彻底弄清楚&#xff0c;今天&#xff0c;我们以阿里为例&#xff0c;来聊聊互联网大厂的面试流程和过程&#xff01; 本篇主要还是聊聊社招的面试过程&#xff01;阿里以及其他的互联网大厂的技术类社招面试&#xff0c;通常情况是 4 个轮次…

gin context和官方context_Go Web 小技巧(一)简化Gin接口代码

不知道大家在使用 Gin 构建 API 服务时有没有这样的问题:参数绑定的环节可不可以自动处理&#xff1f;错误可不可以直接返回&#xff0c;不想写空 return, 漏写就是 bug本文通过简单地封装&#xff0c;利用 go 的接口特性&#xff0c;提供一个解决上述两个问题的思路一、解决过…

7年老Android一次操蛋的面试经历,深度好文

Java基础 Java Object类方法HashMap原理&#xff0c;Hash冲突&#xff0c;并发集合&#xff0c;线程安全集合及实现原理HashMap 和 HashTable 区别HashCode 作用&#xff0c;如何重载hashCode方法ArrayList与LinkList区别与联系GC机制Java反射机制&#xff0c;Java代理模式Jav…

Hadoop大数据应用生态圈中最主要的组件及其关系

Hadoop Common Hadoop Common是在Hadoop0.2版本之后分离出来的HDFS和MapReduce独立子项目的内容&#xff0c;是Hadoop的核心部分&#xff0c;能为其他模块提供一些常用工具集&#xff0c;如序列化机制、Hadoop抽象文件系统FileSystem、系统配置工具Configuration&#xff0c;并…

7年老Android一次操蛋的面试经历,系列教学

公司的需求 不同的公司&#xff0c;不同的需求现在的市场上&#xff0c;公司很多&#xff0c;大致上可以归纳为两个大类&#xff1a;大公司和小公司&#xff0c;他们招聘时对人才的需求也不一样。 小公司 小公司他们一般急需的是能够投入工作的人才&#xff0c;因为公司规模…

丁香园 武汉 神童_杭州、武汉、成都哪个城市更适合程序员发展

很多朋友讨论起房价和职业发展机会&#xff0c;都会提到这三个城市&#xff0c;有的人认为目前杭州房价太贵了&#xff0c;生活成本高&#xff0c;华中的武汉和西部崛起的成都都在鼓励高新技术发展并且有了一定成果&#xff0c;在选择职业发展和定居城市之间该如何取舍呢&#…

Windows 7 64位系统上搭建Hadoop伪分布式环境(很详细)

在开始配置前&#xff0c;我们先了解Hadoop的三种运行模式。 Hadoop的三种运行模式 独立&#xff08;或本地&#xff09;模式&#xff1a;无需运行任何守护进程&#xff0c;所有程序都在同一个JVM上执行。在独立模式下测试和调试MapReduce程序很方便&#xff0c;因此该模式在…

7年老Android一次操蛋的面试经历,讲的太透彻了

由于涉及到的面试题较多导致篇幅较长&#xff0c;我根据这些面试题所涉及到的常问范围总结了并做出了一份学习进阶路线图​​​​​​​及面试题答案免费分享给大家&#xff0c;文末有免费领取方式&#xff01; View面试专题 View的滑动方式View的事件分发机制View的加载流程…