首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Python中的元编程

中的元编程,它通过对Python特性的回顾来更新您的Python知识,这样您就可以更好地理解本文中的概念。...本文也解释了Python中的type函数除了返回一个对象(上层的)的类之外是如何拥有更重要的意义的。然后,讨论了在Python中元编程的方法以及元编程如何简化某些特定类型的任务。...类的命名空间字典被创建(但是还未向字典中添加键值对) 类中的代码开始执行,然后代码中定义的所有属性和方法以及一些其他信息(如'__doc__')被添加到命名空间字典中 将要被创建的这个类的元类被识别(这里是简译了...但是,在我们实现通过元类注入行为之前,让我们来看看Python中更常见的实现元编程的方法。...现在你知道了Python中如何编写元类。 总结 在这篇文章中,介绍了Python中实例,类和元类的关系。也展示了元编程的知识,这是一种操作代码的方法。

55920

Python - 面向对象编程 - 实例方法、静态方法、类方法

实例方法 在类中定义的方法默认都是实例方法,前面几篇文章已经大量使用到实例方法 实例方法栗子 class PoloBlog: def __init__(self, name, age):...self 参数,用于绑定调用此方法的实例对象(Python 会自动完成绑定) 实例方法通常会用实例对象直接调用 通过类名调用实例方法 Python 也支持通过类名调用实例方法,但需要手动给 self...在调用类方法时,无需显式为 cls 参数传参,但传递的并不是实例对象,而是类对象本身 不同点 最大的不同在于需要使用 @classmethod 装饰器才能称为类方法 实际栗子 class PoloBlog...一个方法内部既需要访问实例属性,又需要访问类属性,应该定义为什么方法? 答案:实例方法,因为可以通过 来访问,但在类方法中无法访问实例属性 类对象.类属性 代码栗子直接看上面一个就是啦!...Python 解释器不会对它包含的参数做任何类或对象的绑定,所以静态方法无法调用任何类属性、类方法、实例属性、实例方法,除非通过类名和实例对象 什么时候会用静态方法 类里面封装的方法 既不需要访问实例属性

62540
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Python编程思想(24):类的实例方法

    对于在类中定义的实例方法,Python会自动绑定方法的第1个参数(通常是self),第1个参数总是指向调用该方法的对象。...self参数最大的作用就是引用当前方法的调用者,比如在构造方法中通过self为该对象增加实例变量。也可以在一个实例方法中访问该类的另一个实例方法或变量。...当 Python对象的一个方法调用另一个方法时,不能省略self。也就是说,将上面的move方法改为如下形式是不正确的。...' # 使用self代表该构造方法正在初始化的对象 # 下面的代码将会把该构造方法正在初始化的对象的name实例变量设为Mike self.foo = '...程序中的代码将正在执行初始化的SelfInConstructor对象的name实例变量设为Mike,这意味着该构造方法返回的所有对象的name实例变量都等于Mike。

    56930

    【Groovy】MOP 元对象协议与元编程 ( 方法注入 | 使用 ExpandoMetaClass 进行方法注入 )

    文章目录 一、使用 ExpandoMetaClass 进行方法注入 三、完整代码示例 一、使用 ExpandoMetaClass 进行方法注入 ---- 在 【Groovy】MOP 元对象协议与元编程...( 方法注入 | 同时注入普通方法、静态方法、构造方法 ) 博客中 , 使用 MetaClass 注入 普通方法、静态方法、构造方法 , 其底层原理就是通过 ExpandoMetaClass 进行方法注入...; 我们也可以自己手动实现 ExpandoMetaClass 方法注入过程 ; 如为下面的 Student 类注入方法 ; class Student { def name; } 首先 , 创建...ExpandoMetaClass 实例对象 ; def expandoMetaClass = new ExpandoMetaClass(Student) 然后 , 为其注入方法 , 可以注入 普通方法...() // 使用注入的构造方法初始化 Student 类 def student = new Student("Tom") // 调用注入的普通方法 student.hello() student.say

    25210

    【Groovy】MOP 元对象协议与元编程 ( 使用 Groovy 元编程进行函数拦截 | 使用 MetaClass 进行方法拦截 | 对象上拦截方法 | 类上拦截方法 )

    文章目录 一、使用 MetaClass 进行方法拦截 1、使用 MetaClass 在单个对象上进行方法拦截 2、使用 MetaClass 在类上进行方法拦截 二、完整代码示例 1、对象方法拦截 2...、类方法拦截 一、使用 MetaClass 进行方法拦截 ---- MetaClass 可以定义类的行为 , 可以利用 MetaClass 进行方法拦截 ; Groovy 对象 和 类 都可以获取 MetaClass...MetaClass 在单个对象上进行方法拦截 在 Groovy 对象上获取的元类对象 , student.metaClass 拦截 MetaClass 上的方法 , 使用 元类对象名.方法名 = {闭包..." } 执行 hello 方法时 , 执行的是闭包的内容 , 不再是原来的 hello 方法内容 ; 2、使用 MetaClass 在类上进行方法拦截 在 Groovy 类上获取的元类对象 , Student.metaClass...拦截 MetaClass 上的方法 , 使用 元类对象名.方法名 = {闭包} 进行拦截 , 拦截 MetaClass 类上的方法 , 如 : // 拦截 student 对象上的方法 Student.metaClass.hello

    79710

    【Groovy】MOP 元对象协议与元编程 ( 方法注入 | 使用 Category 分类注入方法 )

    文章目录 一、方法注入 二、使用 Category 分类注入方法 三、完整代码示例 一、方法注入 ---- 在之前的博客中 , 主要是使用 Groovy 元编程 拦截方法 , 改变方法的实现 ; 使用元编程还可以为...Groovy 类 注入一个新的方法 , 方法注入 ; Groovy 方法注入的 3 种方式 : Category 分类注入 MetaClass 账户入 Mixin 注入 上述注入都是通过 运行时元编程...进行方法注入 , 编译时元编程 也可以进行方法注入 ; 二、使用 Category 分类注入方法 ---- 定义 Student 类 , class Student { def name; }...Hello) { new Student(name: "Tom").hello() } use 表示要使用 Hello 类中的注入方法 , 为 Student 类注入 Hello 类中的 hello...方法 , 在下图中可以看到 , 在 use 代码块中 , 可以提示出要注入的方法 ; 三、完整代码示例 ---- 完整代码示例 : class Student { def name; }

    35330

    【Groovy】MOP 元对象协议与元编程 ( 方法注入 | 使用 MetaClass 进行方法注入构造方法 )

    文章目录 一、使用 MetaClass 注入构造方法 二、完整代码示例 一、使用 MetaClass 注入构造方法 ---- 使用 MetaClass 注入构造方法 , 代码格式为 : 被注入构造方法的类...Student.metaClass.constructor = { String str -> new Student(name: str) } 注意 , 构造函数的返回值必须是 Student 对象 ; 这里在注入的构造函数闭包中..., 可以设置若干构造函数参数 , 上述代码中 , 就为构造函数设置了 String 类型参数 ; 使用上述注入的构造函数 , 实例化 Student 对象 , 调用 hello 方法 , 可以成功打印出构造函数中传入的...“Tom” 参数 ; // 使用注入的构造方法初始化 Student 类 def student = new Student("Tom") student.hello() 二、完整代码示例 ----...constructor Student.metaClass.constructor = { String str -> new Student(name: str) } // 使用注入的构造方法初始化

    22220

    实例方法,类方法和静态方法的区别_python中类的所有实例方法

    只能由实例调用 类方法 使用装饰器@classmethod,第一个参数可以是”cls”,也可以是”self”,通过它传递类的属性和方法。...最后,我想定义一些学生,然后获得班级中的总人数 这个问题用类方法做比较合适,因为我实例化的时学生,但是如果我从学生这一个实例中获得班级总人数是不合理的,同时,如果想要获得班级总人数,如果生成一个班级的实例也是没有必要的...使用装饰器 @staticmethod,不需要实例。...静态方法主要用来存放逻辑性的代码,逻辑上属于类,但是和类本身没有交互,也就是说在静态方法中,不会涉及到类中的属性和方法的操作。...我们可以在类外面写一个简单的方法来做这些,但是这样做就扩散了类代码的关系到类定义的外面,这样写就会导致以后代码维护的困难 参考文章 《python中的静态方法和类方法》 《python中类方法,实例方法

    2K40

    【Groovy】MOP 元对象协议与元编程 ( 方法注入 | 使用 MetaClass 进行方法注入普通方法 )

    文章目录 一、使用 MetaClass 进行方法注入 二、完整代码示例 一、使用 MetaClass 进行方法注入 ---- 定义 Student 类 , class Student { def..., 即可注入方法 , 在闭包中 , delegate 就是 Student 对象 ; // 向 Student 类注入 hello 方法 Student.metaClass.hello << {...println delegate println "Hello ${delegate.name}" } 创建 Student 实例对象 , 调用为 Student 类注入的 hello 方法 ,...delegate 代理对象 ; 此处注意 , 注入方法使用 方法 使用 = 运算符 ; 方法注入后 , 在 类 的 metaClass 中注入的方法 , 在任何 Student...对象中 , 都可以调用被注入的 hello 方法 ; 但是在 对象 的 metaClass 中注入的方法 , 只有该 Student 对象才能调用被注入的 hello 方法 , 其它对象不能调用该注入的方法

    23350

    Python中类的静态方法、类方法及实例方法

    概述 在Python的类中,有着类属性、实例属性,静态方法、类方法、实例方法的区别。到底有什么不一样呢?接下来我们就一探究竟。...因此修改类属性,应该使用类对象进行修改。再外界最好不要使用 实例对象.新属性 = xxx,动态创建实例属性。 使用场景 到底是用类属性,还是实例属性?...如果每个实例对象需要具有相同值的属性,那么就使用类属性,用一份既可。...其中 self, cls 只是代指实例对象和类对象,因此换成其他变量也可以,但是约定成俗(为了和其他编程语言统一,减少理解难度),不要搞另类,大家会不明白的。...使用场景 需要操作类属性的定义成类方法。 需要操作实例属性的定义成实例方法。 既不需要操作类属性,也不需要操作实例属性就定义成静态方法。

    2.9K00

    Python中的静态方法、实例方法、类方法的区别

    实例方法 定义:第一个参数必须是实例对象,该参数名一般约定为“self”,通过它来传递实例的属性和方法(也可以传类的属性和方法); 调用:只能由实例对象调用。...类方法 定义:使用装饰器@classmethod。第一个参数必须是当前类对象,该参数名一般约定为“cls”,通过它来传递类的属性和方法(不能传实例的属性和方法); 调用:实例对象和类对象都可以调用。...静态方法 定义:使用装饰器@staticmethod。参数随意,没有“self”和“cls”参数,但是方法体中不能使用类或实例的任何属性和方法; 调用:实例对象和类对象都可以调用。...count = 0 def __init__(self, name): self.name = name Tool.count += 1 # 定义一个实例方法...,逻辑上类方法一般由类自身调用,其实实例对象和类对象都可以调用 Tool.shou_tool_count() # 调用实例方法,只能由实例对象调用 tool.action() # 调用静态方法,实例对象和类对象均可调用

    1.5K20

    【Groovy】MOP 元对象协议与元编程 ( 方法委托 | 使用 @Delegate 注解进行方法委托 )

    文章目录 一、使用 @Delegate 注解进行方法委托 二、完整代码示例 一、使用 @Delegate 注解进行方法委托 ---- 在博客 【Groovy】MOP 元对象协议与元编程 ( 方法委托 |...正常方法调用 | 方法委托实现 | 代码示例 ) 【Groovy】MOP 元对象协议与元编程 ( 方法委托 | 批量方法委托 ) 中 , 都是通过手动方式实现了方法委托 , Groovy 中提供了 @...org.codehaus.groovy.transform.DelegateASTTransformation") public @interface Delegate { } 在被委托对象上 , 直接使用..., 其没有实现 hello1 方法 , 但是被 @Delegate 注解修饰的 Student1 student1 对象中定义了 hello1 方法 , 此时就会自动进行方法委托 , 调用 student1..., 直接通过 StudentManager 对象调用 Student1 中的方法 sm.hello1() // 方法委托, 直接通过 StudentManager 对象调用 Student2 中的方法

    44120

    Python中类的静态方法、类方法及实例方法

    概述 在Python的类中,有着类属性、实例属性,静态方法、类方法、实例方法的区别。到底有什么不一样呢?接下来我们就一探究竟。...因此修改类属性,应该使用类对象进行修改。再外界最好不要使用 实例对象.新属性 = xxx,动态创建实例属性。 使用场景 到底是用类属性,还是实例属性?...如果每个实例对象需要具有相同值的属性,那么就使用类属性,用一份既可。...其中 self, cls 只是代指实例对象和类对象,因此换成其他变量也可以,但是约定成俗(为了和其他编程语言统一,减少理解难度),不要搞另类,大家会不明白的。...使用场景 需要操作类属性的定义成类方法。 需要操作实例属性的定义成实例方法。 既不需要操作类属性,也不需要操作实例属性就定义成静态方法。

    3K10

    【Groovy】MOP 元对象协议与元编程 ( 方法注入 | 使用 Mixin 混合进行方法注入 )

    文章目录 一、使用 Mixin 混合进行方法注入 二、完整代码示例 一、使用 Mixin 混合进行方法注入 ---- 使用 Mixin 混合进行方法注入 , 为下面的 Student 类注入方法 ; class...Student { def name } 首先 , 定义被注入的方法 , 定义一个类 , 在类中定义被注入的方法 , 这里需要注意 , 被注入的方法没有 self 参数 , 不能访问其本身对象..."Hello ${student.name}" } } 然后 , 调用类的 mixin 方法 , 将注入方法所在的类混合进指定的 需要注入方法 的类中 ; 可以直接向 Student 类中混合..., 也可以像 Student.metaClass 中混合 , 二者效果相同 ; // 将 Hello 类中的方法注入到 Student 类中 Student.mixin(Hello) 最后 , 直接调用被注入的方法..., 这里要注意 , 使用 Student 对象调用 hello 方法时 , 同时需要在参数中 , 也传递一个该对象 ; // 创建 Student 对象 def student = new Student

    23520

    【Groovy】MOP 元对象协议与元编程 ( 方法注入 | 使用 MetaClass 注入静态方法 )

    文章目录 一、使用 MetaClass 注入静态方法 二、完整代码示例 一、使用 MetaClass 注入静态方法 ---- 使用 MetaClass 注入静态方法 , 可以使用如下代码实现 : 类名....static'.被注入的静态方法名 = { 闭包 } 定义 Student 类 , 其中定义 name 成员 ; class Student { def name; } 使用上述语法 , 向 Student...类注入 hello 静态方法 ; // 向 Student 类注入 hello 静态方法 Student.metaClass.'...static'.hello = { println "Hello Student ${delegate.name}" } 注意这里在 被注入的 hello 静态方法中 , 使用了 delegate..., 如果使用 Student 类调用 hello 方法 , 则 delegate 就是 Student 类 ; // 通过 Student 类调用静态方法 Student.hello() 如果使用 Student

    21820

    【Groovy】MOP 元对象协议与元编程 ( 使用 Groovy 元编程进行函数拦截 | 动态拦截函数 | 动态获取 MetaClass 中的方法 | evaluate 方法执行Groovy脚本 )

    文章目录 一、基础示例 二、根据字符串动态获取 MetaClass 中的方法 二、使用 evaluate 执行字符串形式的 Groovy 脚本 二、完整代码示例 一、基础示例 ---- 定义类 Student..., my name is Tom, 18 years old 二、根据字符串动态获取 MetaClass 中的方法 ---- 进行动态函数拦截时 , 事先不知道要要拦截的方法名 , 这里声明一个药拦截的方法名变量...; // 要拦截的方法名 def interceptMethodName = "hello" 使用如下代码操作 , 即可获取 MetaClass 中的方法 ; // 函数拦截操作 student.metaClass...${interceptMethodName}" 二、使用 evaluate 执行字符串形式的 Groovy 脚本 ---- 动态函数拦截时 , 也不知道拦截后要执行哪些操作 , 使用 evaluate...interceptMethodName}" = { // 执行 代码 , 传入的参数是 代码的字符串形式 evaluate(interceptAction) } 二、完整代码示例 ---- 完整代码示例 : 在下面的代码中

    1.4K40

    【Groovy】MOP 元对象协议与元编程 ( 使用 Groovy 元编程进行函数拦截 | 通过 MetaClass#invokeMethod 方法调用类其它方法 )

    方法中 , 不能调用 invokeMethod 方法 , 这样调用肯定会出现无限循环递归 , 导致栈溢出 ; 此处只能通过调用 MetaClass#invokeMethod 方法 , 调用相关函数 ;...通过元类对象的 invokeMethod 方法 , 不会导致栈溢出 ; 获取该 Groovy 类的 metaClass , 然后调用 metaClass 的 invokeMethod 方法 , 传入调用对象..., 调用方法 , 方法参数 , 即可调用相关方法 ; // 检查该类中是否定义 name 方法 , 参数是 args def hasMethod = metaClass.invokeMethod...调用 hello 方法 // 第二个参数是函数参数 , 如果为 void 则传入 null //student.invokeMethod("hello", null) // 获取 元方法 //MetaMethod...metaMethod = student.getMetaClass().getMetaMethod("hello", null) // 执行元方法 //metaMethod.invoke(student

    45530

    【Groovy】MOP 元对象协议与元编程 ( 使用 Groovy 元编程进行函数拦截 | 重写 MetaClass#invokeMethod 方法拦截 JDK 中已经定义的函数 )

    --- 重写 MetaClass#invokeMethod 方法 , 不仅可以拦截自定义的类中的方法 , 还可以拦截 JDK 中已经定义完毕的方法 ; 如果要拦截 JDK 中的方法 , 肯定不能使用 实现...GroovyInterceptable 接口的方法 , 只能使用重写 MetaClass#invokeMethod 方法进行拦截 ; 此处以 String 类为例 , 拦截其中的 contains 方法...JDK 中的 String 类中定义的 contains 方法 , 查询字符串中是否包含指定的子串 ; def string = "Hello World" // 查询字符串中是否包含 "Hello...使用下面的方法可以拦截所有的函数 ; def string = "Hello World" string.metaClass.invokeMethod = { String name, Object...: 调用 string 对象中的原来的方法 // 注意此处不能使用 metaClass.invokeMethod 方法调用对象中的方法 , 会导致栈溢出 // 这里通过

    63630
    领券