9.2、面向对象高级特性(类方法和静态方法、property类属性、单例模式)

news2024/11/16 23:38:52

文章目录

  • 类方法和静态方法
  • property类属性
  • 单例模式
    • 基于装饰器实现
    • 使用_ _ new _ _方法实现
  • 面向对象总结

类方法和静态方法

类里面定义的方法称为实例方法,python解释器会自动将对象(或实例)传入方法【pycharm中会自动将self传入,self代表对象】
如果不想自动传入self 对象,希望python解释器自动传入类名,那么就需要使用类方法
静态方法不需要让python解释器传任何东西,python解释器不会自动传入任何参数。

类方法是类对象所拥有的方法,需要用修饰器一般以 @classmethod 来标识其为类方法,
1). 对于类方法,第一个参数必须是类对象,作为第一个参数
(cls是形参, 可以修改为其它变量名,但最好用’cls’了)
2). 能够通过实例对象和类对象去访问。
静态方法需要用修饰器一般以 @staticmethod 来标识其为静态方法,
1). 静态方法不需要多定义参数
2). 能够通过实例对象和类对象去访问。

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

    # 实例方法, python解释器会自动将对象/实例传入方法。
    def get_age(self):
        print('self:', self)
        return  self.age

    # 类方法:python解释器会自动将类传入方法。
    @classmethod
    def get_cls(cls):
        print('cls:', cls)

    # 静态方法:python解释器不会自动传入对象和类名
    # 可以正常传递别的参数
    @staticmethod
    def get_info(name,age):
        print("static method信息",name,age)

if __name__ == '__main__':
    s = Student('张三', 18)
    s.get_age()
    s.get_cls()
    s.get_info('张三', 18)

在这里插入图片描述

property类属性

类属性:将类方法变成类属性的过程
【调用类方法的时候只需要对象名.方法名。方法名后面不需要加括号,使得代码更加简洁】
【实例:将类方法object.year()转变成类属性object.year。】

类属性应用需求: 对于京东商城中显示电脑主机的列表页面,每次请求不可能把数据库中的所有内容都显示到页面上,而是通过分页的功能局部显示,所以在向数据库中请求数据时就要显示的指定获取从第m条到第n条的所有数据 这个分页的功能包括:
1、根据用户请求的当前页和总数据条数计算出 m 和 n
2、根据m 和 n 去数据库中请求数据

class Page:
    """
        数据库内容:[user1, user2, user3......user100]
        page=2, per_page=10
        第一页: start=0 end=10
        第二页: start=10 end=20
        第三页: start=20 end=30
        ....
        第page页: start=(page-1)*per_page end=page*per_page
        """
    def __init__(self, page, per_page=10):
        self.page = page
        self.per_page = per_page
    @property
    def start(self):
        return (self.page - 1) * self.per_page
    @property
    def end(self):
        return self.page * self.per_page
if __name__ == '__main__':
    content = ['content' + str(i + 1) for i in range(101)]
    p = Page(10, 5)
    print(content[p.start:p.end])

在这里插入图片描述

单例模式

简单来说,单例模式就是一个类只能构建一个对象的设计模式

对于系统中的某些类来说,只有一个实例很重要,例如,一个系统中可以存在多个打印任务,但是只能有一个正在工作的任务;一个系统只能有一个窗口管理器或文件系统;一个系统只能有一个计时工具或ID(序号)生成器。如在Windows中就只能打开一个任务管理器。如果不使用机制对窗口对象进行唯一化,将弹出多个窗口,如果这些窗口显示的内容完全一致,则是重复对象,浪费内存资源;如果这些窗口显示的内容不一致,则意味着在某一瞬间系统有多个状态,与实际不符,也会给用户带来误解,不知道哪一个才是真实的状态。因此有时确保系统中某个对象的唯一性即一个类只能有一个实例非常重要。

class People(object):
    pass

p1 = People()  # object
p2 = People()  # object
print(p1, p2)  

每个对象的内存地址不同,肯定不是单例模式
在这里插入图片描述

基于装饰器实现

from functools import wraps
# 使用装饰器来装饰类
def singleton(cls):
    #通过一个字典存储类和对象信息{"class":"object"},
    #需要实例化对象的时候,就将类名作为key值,对象名作为value值。
    #若已实例化对象过,当再次实例化对象的时候,就将已经有的对象即value值返回
    instances={}
    @wraps(cls)
    def wrapper(*args,**kwargs):
        # 为了保证单例模式,判断该类是否已经实例化对象
        # 1、如果有对象,直接返回存在的对象
        # 2、如果没有,则实例化对象,并存储类和对象到字典中,最后返回
        if instances.get(cls):
            return instances.get(cls)
        object=cls(*args,**kwargs)
        instances[cls]=object
        return object
    return wrapper

@singleton
class People:
    pass

p1=People()
p2=People()
#查看是否单例模式
print(p1 is p2) #p1和p2值是否相同以及内存地址是否相同

在这里插入图片描述

使用_ _ new _ _方法实现

_ _ new _ _方法在实例化对象之前执行,用于创建对象
_ _ init _ 方法用于将对象和属性绑定,在 _ new _ _方法之后执行

class People(object):
    def __init__(self):
        print("执行__init__方法")
    def __new__(cls,*args,**kwargs):
        print("执行__new__方法")
        return object.__new__(cls) #执行父类object的new方法

p1=People()

在这里插入图片描述

class People(object):
    _instance = None

    def __new__(cls, *args, **kwargs):
        #创建对象之前执行的内容
        if cls._instance is None:
            cls._instance = object.__new__(cls)  # 调用父类的new方法创建一个对象
        return cls._instance

    def __init__(self):
        """在new方法之后执行, 将属性和对象封装在一起"""
        print("执行__init__方法")

p1 = People()
p2 = People()
print(p1 is p2, p1, p2) #p1和p2内存地址相同,是同一个对象

在这里插入图片描述

面向对象总结

"""
面向对象:
    1. 三大特性
        封装(非常重要):
            __new__: 在实例化对象之前执行的, 返回对象。
            __init__: 构造方法, 实例化对象时自动执行。 常用于将对象和属性绑定在一起。
            self: 实质上是对象。
        继承(非常重要):
            多继承算法: python3中广度优先算法。
            私有属性和私有方法:只能在类里面访问和操作,类外部和子类不能访问
        多态:同一操作作用于不同的对象,可以有不同的解释,产生不同的执行结果

    2. 三大特性的应用
        1). 链表的封装
        2). 栈的封装
        3). 队列的封装
        4). 二叉树的封装与遍历

    3. 高级特性
        1). @classmethod和@staticmethod(类方法和静态方法)
        2). @property类属性,使得代码更加简洁
        3). 单例模式: 一个类只能实例化一个对象
            基于装饰器
            基于new方法
"""

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

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

相关文章

【机器学习】支持向量机【下】软间隔与核函数

有任何的书写错误、排版错误、概念错误等,希望大家包含指正。 在阅读本篇之前建议先学习: 【机器学习】拉格朗日对偶性 【机器学习】核函数 由于字数限制,分成两篇博客。 【机器学习】支持向量机【上】硬间隔 【机器学习】支持向量机【下】…

研发效能工程实践-利用Superset快速打造大数据BI平台

大数据BI平台自研之殇 随着互联网发展,现在随便哪个公司都手握大量数据。如何利用这些数据为公司商业带来价值,触使各个公司投入大量人力财力去做商业智能。 早期的BI可能就是公司Leader叫开发小哥写几句SQL导出数据,然后导入到Excel里绘制几…

echarts:nuxt项目使用echarts

一、项目环境 nuxt 2.X vue2.X vuex webpack 二、安装 yarn add echarts 三、使用 3.1、plugins目录下创建echarts.js import Vue from vue import * as echarts from echarts // 引入echarts Vue.prototype.$echarts echarts // 引入组件(将echarts注册为全…

认证服务-----技术点及亮点

大技术 Nacos做注册中心 把新建的微服务注册到Nacos上去 两个步骤 在配置文件中配置应用名称、nacos的发现注册ip地址,端口号在启动类上用EnableDiscoveryClient注解开启注册功能 使用Redis存验证码信息 加入依赖配置地址和端口号即可 直接注入StringRedisTempla…

HTML静态网页作业——关于我的家乡介绍安庆景点

家乡旅游景点网页作业制作 网页代码运用了DIV盒子的使用方法,如盒子的嵌套、浮动、margin、border、background等属性的使用,外部大盒子设定居中,内部左中右布局,下方横向浮动排列,大学学习的前端知识点和布局方式都有…

Armbian搭建本地Gitea服务器

Armbian搭建本地Gitea服务器 1 安装Docker Docker 是一个用于开发、发布和运行应用程序的开放平台。 Docker 是一个开源的应用容器引擎,Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的容器中,然后发布到任何流行的 Linux 机器上&…

R语言中的prophet预测时间序列数据模型

本文 将针对R进行的几次建模练习的结果,以魁北克数据为依据,分为13年的训练和1年的测试。prophet与基本线性模型(lm),一般加性模型(gam)和随机森林(randomForest)进行了比…

ES6:ES6 的新增语法

什么是 ES6 ? ES 的全称是 ECMAScript , 它是由 ECMA 国际标准化组织,制定的一项脚本语言的标准化规范。 年份 版本 2015年6月 ES2015 2016年6月 ES2016 2017年6月 ES2017 2018年6月 ES2018 … … ES6 实际上是一个泛指,泛指 ES2015 及后续的版本。 …

基于最大熵图像插值Maximum Entropy插值算法的图像超分辨重构研究-附Matlab代码

⭕⭕ 目 录 ⭕⭕✳️ 一、引言✳️ 二、图像复原基本原理✳️ 三、最大熵图像插值原理✳️ 四、实验验证✳️ 五、参考文献✳️ 六、Matlab程序获取与验证✳️ 一、引言 图像是一种表达信息的形式,其中,数字图像反馈的信息更加丰富。 在获取图像的过程中…

基于N32G45的按键驱动

基于N32G45的按键驱动 1.N32G45简介 N32G45系列集成了最新一代嵌入式ARM Cortex™-M4F处理器,在Cortex™-M3内核的基础上强化了运算能力、新增加了浮点运算处理单元(FPU)、DSP和并行计算指令,提供1.25DMIPS/MHz的优异性能。同时其…

JAVA复习【11】单列集合Collection:ArrayList、 LinkedList、HashSet、TreeSet学习与使用

1.首先思考一个问题:为什么要有集合? 我们也知道,数组可以保存多个对象,但是在某些情况下无法确定到底需要保存多少个对象,此时数组不再适用没因为数组的长度不可变,例如,要保存一个学校的学生信…

移动WEB开发之rem布局--less基础

维护 css 的弊端 CSS 是一门非程序式语言,没有变量、函数、SCOPE(作用域)等概念。 CSS 需要书写大量看似没有逻辑的代码,CSS 冗余度是比较高的。 不方便维护及扩展,不利于复用。 CSS 没有很好的计算能力 非前端开…

前馈神经网络与支持向量机实战 --- 手写数字识别

前馈神经网络与支持向量机实战 — 手写数字识别 文章目录前馈神经网络与支持向量机实战 --- 手写数字识别一、前馈神经网络介绍二、支持向量机介绍三、数据集说明四、环境准备五、实验要求六、Python代码tutorial_minst_fnn-keras.py:使用TensorFlow的Sequential实现…

Linux开发常用ps命令选项详解

【摘要】本文介绍了在Linux应用/内核开发调试中,经常需要用到的两个选项组合,当然,如果你需要查看更多更详尽的选项说明,可以参考man说明文档,即命令行下输入man ps进行查看。 aux选项组合 使用场景:更多…

算法日常训练12.4(最接近目标价格甜点成本)

只能说回溯实在是诡异,刚看到这题目思路一点不清晰,想着用回溯想到一点写一点,就这样诡异的出来了。 主要回溯思想,由于冰淇淋基料只能选一种,那就对数组遍历,每次对一种冰淇淋基料继续回溯,用r…

Proxmox VE 修改集群名称

作者:田逸(formyz) Proxmox VE集群一旦创建,其集群的名称就固定下来。在Proxmox VE Web管理后台,没有相应的菜单或按钮对应与集群名称的修改(仅仅发现修改虚拟机选项有修改名称的地方)。在宿主系统Debian下…

网课题库接口

网课题库接口 本平台优点: 多题库查题、独立后台、响应速度快、全网平台可查、功能最全! 1.想要给自己的公众号获得查题接口,只需要两步! 2.题库: 题库:题库后台(点击跳转) 题库…

[附源码]计算机毕业设计文曦家教预约系统Springboot程序

项目运行 环境配置: Jdk1.8 Tomcat7.0 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。 项目技术: SSM mybatis Maven Vue 等等组成,B/S模式 M…

java计算机毕业设计ssm社团管理系统9e73v(附源码、数据库)

java计算机毕业设计ssm社团管理系统9e73v(附源码、数据库) 项目运行 环境配置: Jdk1.8 Tomcat8.5 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。…

计及新能源出力不确定性的电气设备综合能源系统协同优化(Matlab代码实现)

目录 第一部分 文献一《计及新能源出力不确定性的电气设备综合能源系统协同优化》 0 引言 1 新能源出力不确定性处理 1.1 新能源出力预测误差分布 1.2 新能源出力的时间相关性 1.3 场景生成 2 计及温控负荷调节能力的电气综合能源系统协同优化建模…