草庐IT

09-Python之路-进阶-面向对象-类与方法

程序记录日志 2023-03-28 原文

类属性

  • 类属性就是给类对象中定义的属性,通常用来记录与这个类相关的特征
  • 类属性不会记录具体对象的特征

属性的获取机制

  • 在Python中属性的获取存在一个向上查找机制。因此,要访问类属性有两种方式:(类名、类属性),(对象、类属性)
  • 向上查找机制:获取对象属性时,首先在对象内部查找对象属性,没有找到就会向上寻找类属性
  • 如果使用 对象.类属性 = 值赋值语句,只会给对象添加一个属性,而不会影响到类属性的值

类方法

  • 类方法就是针对类对象定义的方法,在类方法内部可以直接访问类属性或调用其他的类方法

语法

@classmethod
def 类方法名(cls):
    pass
  • 类方法需要使用修饰器@classmethod来标识,告诉解释器这是一个类方法。
  • 类方法第一个参数应该是cls。由哪个类调用的方法,方法内的cls就是哪一个类的引用。
  • 类方法参数和self类似,通过类名.调用类方法,调用方法时,不需要传递cls参数。在方法内部可以通过cls.访问类的属性,也可以通过cls.调用其他的类方法

扩展

静态方法

  • 当 类中某个方法即不需要访问实例属性或者调用实例方法也不需要访问类属性,或者调用类方法的时候可以把这个方法封装成一个静态方法
  • 静态方法需要用修饰器@staticmethod来标识,告诉解释器这是一个静态的方法。通过类名.调用静态方法

语法

@staticmethod
def 静态方法名():
    pass
  • 实例方法:由对象调用;至少一个self参数;执行实例方法时,自动调用该方法的对象赋值给self
  • 类方法:由类调用;至少一个cls参数;执行类方法时,自动将调用该方法的类赋值给cls
  • 静态方法:由类调用,无默认参数
  • 相同点:对于所有的方法而言,均属于类,所以在内存中也只保存一份
  • 不同点:方法调用者不同、调用方法时自动传入参数不同

单例

单例设计模式

  • 目的:让类创建的对象,在系统中只有唯一的一个实例,每一次执行类名()返回的对象,内存地址是相同的

new方法

  • 使用类名()创建对象时,Python会先调用new方法为对象分配空间
  • 重写__new__方法要return super().__new__(cls),否则Python的解释器得不到分配空间的对象引用,就不会调用对象的初始化方法

作用

  • 在内存中为对象分配空间
  • 返回对象的引用

实例

  1. 定义一个类属性,初始值是None,用于记录单例对象的引用
  2. 重写new方法
  3. 如果类属性is None,调用父类方法分配空间,并在类属性中记录结果
  4. 返回类属性中记录的对象引用
class Singleton(object):
    # 定义类属性记录单例对象引用
    instance = None
    
    def __new__(cls,*args,**kwargs):
        # 1.判断类属性是否已经被赋值
        if cls.instance is None:
            cls.instance = super().__new__(cls)
        
        # 2.返回类属性的单例引用
        return cls.instance
        
  1. 定义一个类属性init_flag标记是否执行过初始化动作,初始值为False
  2. init方法中,判断init_flag,如果为False就执行初始化动作
  3. 然后将init_flag设置为True
  4. 再次自动调用init方法时,初始化动作就不会再次执行
class Singleton(object):
    # 记录第一个被创建对象的引用
    instance = None
    # 记录是否执行过初始化操作
    init_flag = False
    
    def __new__(cls,*args,**kwargs):
        # 1.判断类属性是否是空对象
        if cls.instance in None:
        # 2.调用父类的方法,为第一个对象分配空间
        cls.instance = super().__new__(cls)
        # 3.返回类属性保存的对象引用
        return cls.instance
        
    def __init__(self):
        if not Singleton.init_flag:
            print("初始化单例")
            
            Singleton.init_flag = True
            
# 创建多个对象
singleton1 = Singleton()
print(singleton1)

singleton2 = Singleton()
print(singleton2)

property属性

定义

  • 一种用起来像是使用的实例属性一样的特殊属性。property属性内部进行一系列的逻辑计算,最终将计算结果返回

注意

  • 定义时,在实例方法的基础上添加@property装饰器一个,并且只有一个self参数
  • 调用时,无需括号
方法:foo_obj.func()
property属性:foo_obj.prop

两种方式

  • 装饰器:在方法上应用装饰器
  • 类属性:在类中定义值为property对象的类属性

类属性访问方式

三种类属性访问方式

  • @property:获取
  • @proerty.setter:修改
  • @property.deleter:删除

参数(property四个参数)

  • 第一个参数:方法名,调用对象属性时,自动触发执行方法
  • 第二个参数:方法名,调用对象属性 = XXX时,自动触发执行方法
  • 第三个参数:方法名,调用del对象属性时,自动触发执行方法
  • 第三个参数:字符串,调用对象属性.__doc__,此参数用来描述该属性信息

魔法属性

  • __init__:初始化方法,通过类创建对象时,自动触发执行
  • __doc__:表示类的描述信息`
  • __module__:表示当前操作的对象在哪个模块
  • __class__:表示当前操作的对象的类是什么
  • __del__:当对象在内存中被释放时,自动触发执行
  • __call__:对象后面加括号,触发执行
  • __dict__:类或对象中的所有属性(类的实例属性属于对象,类中的类属性和方法属于类)
  • __str__:如果一个类中定义了str方法,那么在打印对象时,默认输出该方法的返回值
  • __getitem____setitem____delitem__:用于索引操作
  • __getslice____setslice____delslice__:用于切片操作

有关09-Python之路-进阶-面向对象-类与方法的更多相关文章

  1. ruby - 如何使用 Nokogiri 的 xpath 和 at_xpath 方法 - 2

    我正在学习如何使用Nokogiri,根据这段代码我遇到了一些问题:require'rubygems'require'mechanize'post_agent=WWW::Mechanize.newpost_page=post_agent.get('http://www.vbulletin.org/forum/showthread.php?t=230708')puts"\nabsolutepathwithtbodygivesnil"putspost_page.parser.xpath('/html/body/div/div/div/div/div/table/tbody/tr/td/div

  2. ruby - 如何从 ruby​​ 中的字符串运行任意对象方法? - 2

    总的来说,我对ruby​​还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用

  3. ruby - 为什么我可以在 Ruby 中使用 Object#send 访问私有(private)/ protected 方法? - 2

    类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc

  4. ruby - Facter::Util::Uptime:Module 的未定义方法 get_uptime (NoMethodError) - 2

    我正在尝试设置一个puppet节点,但ruby​​gems似乎不正常。如果我通过它自己的二进制文件(/usr/lib/ruby/gems/1.8/gems/facter-1.5.8/bin/facter)在cli上运行facter,它工作正常,但如果我通过由ruby​​gems(/usr/bin/facter)安装的二进制文件,它抛出:/usr/lib/ruby/1.8/facter/uptime.rb:11:undefinedmethod`get_uptime'forFacter::Util::Uptime:Module(NoMethodError)from/usr/lib/ruby

  5. python - 如何使用 Ruby 或 Python 创建一系列高音调和低音调的蜂鸣声? - 2

    关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。

  6. ruby-on-rails - 按天对 Mongoid 对象进行分组 - 2

    在控制台中反复尝试之后,我想到了这种方法,可以按发生日期对类似activerecord的(Mongoid)对象进行分组。我不确定这是完成此任务的最佳方法,但它确实有效。有没有人有更好的建议,或者这是一个很好的方法?#eventsisanarrayofactiverecord-likeobjectsthatincludeatimeattributeevents.map{|event|#converteventsarrayintoanarrayofhasheswiththedayofthemonthandtheevent{:number=>event.time.day,:event=>ev

  7. Ruby 方法() 方法 - 2

    我想了解Ruby方法methods()是如何工作的。我尝试使用“ruby方法”在Google上搜索,但这不是我需要的。我也看过ruby​​-doc.org,但我没有找到这种方法。你能详细解释一下它是如何工作的或者给我一个链接吗?更新我用methods()方法做了实验,得到了这样的结果:'labrat'代码classFirstdeffirst_instance_mymethodenddefself.first_class_mymethodendendclassSecond使用类#returnsavailablemethodslistforclassandancestorsputsSeco

  8. ruby-on-rails - Rails 3.2.1 中 ActionMailer 中的未定义方法 'default_content_type=' - 2

    我在我的项目中添加了一个系统来重置用户密码并通过电子邮件将密码发送给他,以防他忘记密码。昨天它运行良好(当我实现它时)。当我今天尝试启动服务器时,出现以下错误。=>BootingWEBrick=>Rails3.2.1applicationstartingindevelopmentonhttp://0.0.0.0:3000=>Callwith-dtodetach=>Ctrl-CtoshutdownserverExiting/Users/vinayshenoy/.rvm/gems/ruby-1.9.3-p0/gems/actionmailer-3.2.1/lib/action_mailer

  9. ruby - Highline 询问方法不会使用同一行 - 2

    设置:狂欢ruby1.9.2高线(1.6.13)描述:我已经相当习惯在其他一些项目中使用highline,但已经有几个月没有使用它了。现在,在Ruby1.9.2上全新安装时,它似乎不允许在同一行回答提示。所以以前我会看到类似的东西:require"highline/import"ask"Whatisyourfavoritecolor?"并得到:Whatisyourfavoritecolor?|现在我看到类似的东西:Whatisyourfavoritecolor?|竖线(|)符号是我的终端光标。知道为什么会发生这种变化吗? 最佳答案

  10. ruby-on-rails - 如何验证非模型(甚至非对象)字段 - 2

    我有一个表单,其中有很多字段取自数组(而不是模型或对象)。我如何验证这些字段的存在?solve_problem_pathdo|f|%>... 最佳答案 创建一个简单的类来包装请求参数并使用ActiveModel::Validations。#definedsomewhere,atthesimplest:require'ostruct'classSolvetrue#youcouldevencheckthesolutionwithavalidatorvalidatedoerrors.add(:base,"WRONG!!!")unlesss

随机推荐