zoukankan      html  css  js  c++  java
  • 类的函数调用和对象的绑定方法

    • 在类内部定义的函数,分为2大类:
      1,绑定方法: 绑定给谁,就应该由谁调用,谁来调用就把调用者当作第一个参数自动传入
      绑定到对象的方法: 在类内部定义的没有被任何装饰器修饰的,对象自动传值
      绑定到类的方法: 在类内部定义的被装饰器classmethod修饰的方法

      2,非绑定方法: 没有自动传值这么一说,就是一个普通函数,对象和类都可以使用
      非绑定方法: 不与类或者对象绑定

    面向对象中的@classonlymethod 与 @classmethod的区别

    如果要使用classonlymethod ,则需要先定义好一个classonlymethod 类。
    首先我们需要明白无论是classonlymethod还是classmethod,本质都是一个类,而classonlymethod继承了classmethod。

    classonlymethodz作用:只能被类调用,不能被实例对象调用。

    class classonlymethod(classmethod):  # 继承classmethod
        def __get__(self, instance, cls=None): # 
            if instance is not None:
                raise AttributeError("This method is available only on the class, not on instances.")
            return super(classonlymethod, self).__get__(instance, cls)
    
    from django.utils.decorators import classonlymethod
    
    class Foo:
        def __init__(self, name, a = None):
            self.name = name
    
        def tell(self):    # 绑定到对象
            print('名字是%s'%self.name)
            return self.name
    
        @classonlymethod # classmethod可以被一个实例调用, 但是classonlymethod不能,它只能被类调用.
        def tell2(cls, page=None):    # 绑定到对象
            print('@classonlymethod名字是%s' %cls.tell)
            if page is not None:
                print(page,'page你好啊')
    
        @classmethod   # 绑定到类
        def func(cls):
            print(cls,'这是classmethod')
    
        @staticmethod    # 非绑定方法,静态方法
        def func1(x,y):
            print(x+y)
    
    
    f = Foo('egon')
    # print(f,'对象f')
    # print(Foo.tell,'类方法tell')
    # print(Foo.tell(f),'类方法tell()运行')
    # Foo.tell(f)
    # print(f.tell,'对象方法tell')
    # def func3():print('这是函数func3')
    # print(Foo.func,'函数func')
    
    Foo.func()
    
    # print('----------------------')
    Foo.tell2()
    Foo.tell2(123)
    # print('----------------------')
    # # f.tell2()
    Foo.as_view(actions='get')
    # f.func3()
    # print(Foo.func1)
    # print(f.func1)
    
    Foo.func1(1,2)
    f.func1(1,3)
    输出:
    <class '__main__.Foo'> 这是classmethod
    @classonlymethod名字是<function Foo.tell at 0x000000000A0021E0>
    @classonlymethod名字是<function Foo.tell at 0x000000000A0021E0>
    123 page你好啊
    3
    4
    
    #_*_ encoding: utf-8 _*_   @author: ty  hery   2019/8/21
    
    from types import FunctionType
    
    class Foo(object):
        def func(self,name):
            print(name)
    
    obj = Foo()
    obj.func('alex')  # 对象调用方法直接调用(self是 对象自己,name是'alex'  打印出 alex
    print('---------------------------')
    Foo.func('obj1','egon')      # 类调用方法类名调用(自己传入作为对象的名称,name是'alex'  打印出 egon
    print('======================')
    print(obj.func)  # <bound method Foo.func of <__main__.Foo object at 0x00000000023C0B38>>  绑定方法
    print(Foo.func) # <function Foo.func at 0x00000000023AA950>  函数
    
    写入自己的博客中才能记得长久
  • 相关阅读:
    通过编程添加Outlook联系人和通讯组
    一个比较完整的WindowsFormsApplication实现
    读书笔记:《粘住:为什么我们记住了这些,忘掉了那些?》
    最新购书
    新买的2本书都不错
    压榨机器,Hack,设计极限强度的网络应用
    方向越来越明确了
    思想上激进,行为上保守
    一种遗失了很久的感觉正在慢慢回归
    物极必反,滥用闭包的结果就是回归结构化编程
  • 原文地址:https://www.cnblogs.com/heris/p/14015135.html
Copyright © 2011-2022 走看看