先看下hasattr和getattr在反射中的用法

import sys
class apache(object):
def __init__(self,tcp):
self.tcp = tcp
def start(self):
print("apache is starting,host id is [%s]" %self.tcp)
def stop(self):
print("apache is stoping,host id is [%s]" %self.tcp)
def restart(self):
self.stop()
self.start() if __name__ == '__main__':
server = apache("333")
if hasattr(server,sys.argv[1]): #判断实例中是否有ays.argv[1]这个方法
func = getattr(server,sys.argv[1]) #获取server.sys.argv[1]方法的内存地址
func() #执行server.sys.argv[1]这个方法 # apache is starting,host id is [333]

再看下setattr在反射中的运用

import sys
class apache(object):
def __init__(self,tcp):
self.tcp = tcp
def start(self):
print("apache is starting,host id is [%s]" %self.tcp)
def stop(self):
print("apache is stoping,host id is [%s]" %self.tcp)
def restart(self):
self.stop()
self.start() def test_run(name):
print("running",name) if __name__ == '__main__':
server = apache("333")
setattr(server,"run",test_run)
#我们可以看到,本来server这个实例本身是没有test_run这个方法的,且test_run和apache这个类根本就没有任何关系,但是我们通过setattr方法,就可以把外面的函数赋值给
#某个实例,比如这里的例子,我们就把函数test_run的内存地址赋值给了server.run,也就是说test_run == server.run
#注意,这里只绑定到server这实例上,其他实例还是不能用test_run这个方法的
server.run("alex") #上面的例子中,在test_run中不能使用实例变量,我们可以通过下面的方法就可以实现test_run函数可以调用实例变量 #定义函数需要按照下面的格式来定义
def test_run(self,name):
print("running",name,self.tcp) if __name__ == '__main__':
server = apache("333")
setattr(server,"run",test_run)
#调用的时候需要这样调用
server.run(server,"alex")

最后看下delattr在反射中的运用

import sys
class apache(object):
def __init__(self,tcp):
self.tcp = tcp
def start(self):
print("apache is starting,host id is [%s]" %self.tcp)
def stop(self):
print("apache is stoping,host id is [%s]" %self.tcp)
def restart(self):
self.stop()
self.start() if __name__ == '__main__':
server = apache("1000")
# delattr(server,"stop")
# server.stop() #这样的写法是错误的,因为stop这个方法不属于对象,而属于类,所以删除对象中的stop方法肯定是不可以的
print(server.tcp)
# 1000
# delattr(server,"tcp")
# print(server.tcp)
#所以如果我们删除对象的话,只能删除对象的变量,上面这个例子,我们就可以删除对象中的变量,然后在打印就发现没有这个值了 # 所以如果要删除方法,那么我们只能删除类的方法,而不能删除对象的方法,因为方法都是属于类的 #在删之前我们先判断一下对象中是否有stop这个方法
if hasattr(apache,"stop"):
print(True)
else:
print(False) # True 结果证明有stop这个方法 #在删之后我们在判断一下对象中是否有stop这个方法
delattr(apache,"stop")
if hasattr(apache,"stop"):
print(True)
else:
print(False)
# False 结果证明没有stop这个方法

  

python之面向对象之反射运用的更多相关文章

  1. Python之面向对象进阶------反射(Day26)

    一 classmethod class Classmethod_Demo(): role = 'dog' @classmethod def func(cls): print(cls.role) Cla ...

  2. Python之面向对象之反射、内置方法

    一.静态方法(staticmethod)和类方法(classmethod) 类方法:有个默认参数cls,并且可以直接用类名去调用,可以与类属性交互(也就是可以使用类属性) 静态方法:让类里的方法直接被 ...

  3. python 之 面向对象(反射、__str__、__del__)

    7.10 反射 下述四个函数是专门用来操作类与对象属性的.通过字符串来操作类与对象的属性,这种操作称为反射 class People: country="China" def __ ...

  4. Python 面向对象之反射

    Python 面向对象之反射 TOC 什么是反射? hasattr getattr setattr delattr 哪些对象可以使用反射 反射的好处 例子一 例子二 什么是反射? 程序可以访问.检查和 ...

  5. python 面向对象之反射及内置方法

    面向对象之反射及内置方法 一.静态方法(staticmethod)和类方法(classmethod) 类方法:有个默认参数cls,并且可以直接用类名去调用,可以与类属性交互(也就是可以使用类属性) 静 ...

  6. Python之面向对象反射

    Python之面向对象反射 isinstance(obj,cls)检查是否obj是否是类 cls 的对象 1 class Foo(object): 2 pass 3 4 obj = Foo() 5 6 ...

  7. 百万年薪python之路 -- 面向对象之 反射,双下方法

    面向对象之 反射,双下方法 1. 反射 计算机科学领域主要是指程序可以访问.检测和修改它本身状态或行为的一种能力(自省) python面向对象中的反射:通过字符串的形式操作对象相关的属性.python ...

  8. python基础——面向对象进阶

    python基础--面向对象进阶 1.isinstance(obj,cls)和issubclass(sub,super) isinstance(obj,cls)检查是否obj是否是类 cls 的对象 ...

  9. python学习------面向对象的程序设计

    一 面向对象的程序设计的由来 1940年以前:面向机器 最早的程序设计都是采用机器语言来编写的,直接使用二进制码来表示机器能够识别和执行的指令和数 据.简单来说,就是直接编写 和 的序列来代表程序语言 ...

随机推荐

  1. [UE4]GameMode

    GameMode定义了正在玩的游戏规则,积分等方面,游戏中有些数据和逻辑不适合放在某一个对象身上,这些数据在整个游戏运行中腰持续存在的(比如:积分.排名). 每次游戏一启动,GameMode就被创建, ...

  2. mysql设置索引

    1.添加PRIMARY KEY(主键索引) 语法:ALTER TABLE `表名` ADD PRIMARY KEY ( `列名称` ) mysql>ALTER TABLE `table_name ...

  3. Python print函数参数详解

    官方文档 print(…)    print(value, …, sep=’ ‘, end=’\n’, file=sys.stdout, flush=False)    Prints the valu ...

  4. nginx技术分享 (转)

    原文地址:http://blog.csdn.net/nethibernate/article/details/6628267 Nginx的作用: HTTP Server 反向代理,用于将用户的请求转发 ...

  5. 显式锁(三)读写锁ReadWriteLock

    前言:   上一篇文章,已经很详细地介绍了 显式锁Lock 以及 其常用的实现方式- - ReetrantLock(重入锁),本文将介绍另一种显式锁 - - 读写锁ReadWriteLock.    ...

  6. UVA439-水题

    题意:一只棋盘上的马,从一个点到另外一个点要走多少步 解法:广搜 #include<stdio.h> #include<iostream> #include <strst ...

  7. (12/24) css进阶:sass文件的打包和分离

    1.安装sass打包的loader 这里需要 在项目目录下用npm安装两个包.node-sass和sass-loader,(也可以使用cnpm安装) 因为sass-loader依赖于node-sass ...

  8. OpenCL 双调排序 GPU 版

    ▶ 参考书中的代码,写了 ● 代码,核函数文件包含三中算法 // kernel.cl __kernel void bitonicSort01(__global uint *data, const ui ...

  9. DDD-002

    项目实践:http://www.cnblogs.com/daoqidelv/p/7499662.html#_label0 https://www.cnblogs.com/lonelyxmas/p/79 ...

  10. css之单边阴影

    css之单边阴影 需求:在网上找的其他博客上说单边阴影需要牺牲掉模糊,实际上牺牲掉模糊直接用border不就好了 效果: 原理: 1.在左边的外阴影就是右边的内阴影 2.将box-shadow写在be ...