一、静态属性

静态属性说的就是数据属性

1、定义一个房间的类,求下这个房间的面积

class Room:
def __init__(self,name,ower,width,length,heigh):
self.Name=name
self.Ower=ower
self.Width=width
self.Length=length
self.Heigh=heigh r1=Room("厕所","北爷",2,2,20000)#实例化出来一个实例r1,实例化的过程就是执行__init__
print(r1.__dict__)#查看下r1这个实例的属性字典
print("%s 住的%s 总面积是%s平米的地下室" %(r1.Ower,r1.Name,r1.Width*r1.Length))#进行字符串拼接 C:\python35\python3.exe D:/pyproject/day25/静态属性.py {'Length': 2, 'Ower': '北爷', 'Name': '厕所', 'Heigh': 20000, 'Width': 2} 北爷 住的厕所 总面积是4平米的地下室

2、又来了一个人,又要求下他的房子的面积

class Room:
def __init__(self,name,ower,width,length,heigh):
self.Name=name
self.Ower=ower
self.Width=width
self.Length=length
self.Heigh=heigh
r1=Room("厕所","北爷",2,2,20000)#实例化出来一个实例r1,实例化的过程就是执行__init__
r2=Room("北京","喵爷",20,60,20000)
# print(r1.__dict__)#查看下r1这个实例的属性字典
print("%s 住的%s 总面积是%s平米的地下室" %(r1.Ower,r1.Name,r1.Width*r1.Length))#进行字符串拼接
print("%s 住的%s 总面积是%s平米的地下室" %(r2.Ower,r2.Name,r2.Width*r1.Length)) C:\python35\python3.exe D:/pyproject/day25/静态属性.py 北爷 住的厕所 总面积是4平米的地下室 喵爷 住的北京 总面积是40平米的地下室

3、我们这样做肯定是不行的。这相当于是在外面完成的这件事情,而且很麻烦,应该把这个计算面积弄成一个函数

class Room:
def __init__(self,name,ower,width,length,heigh):
self.Name=name
self.Ower=ower
self.Width=width
self.Length=length
self.Heigh=heigh
def cal_area(self):
print("%s 住的%s 总面积是%s平米的地下室" %(self.Ower, self.Name, self.Width * self.Length))
r1=Room("厕所","北爷",2,2,20000)#实例化出来一个实例r1,实例化的过程就是执行__init__
r2=Room("北京","喵爷",20,60,20000)#实例化第二个实例
r1.cal_area()#实例调用类的函数属性会自动传实例本身作为参数
r2.cal_area()#实例调用类的函数属性会自动传实例本身作为参数 C:\python35\python3.exe D:/pyproject/day25/静态属性.py 北爷 住的厕所 总面积是4平米的地下室 喵爷 住的北京 总面积是1200平米的地下室

4、property装饰器

class Room:
def __init__(self,name,ower,width,length,heigh):
self.Name=name
self.Ower=ower
self.Width=width
self.Length=length
self.Heigh=heigh
@property #把一个方法变成一个数据属性
def cal_area(self):
print("%s 住的%s 总面积是%s平米的地下室" %(self.Ower, self.Name, self.Width * self.Length))
r1=Room("厕所","北爷",2,2,20000)#实例化出来一个实例r1,实例化的过程就是执行__init__
r2=Room("北京","喵爷",20,60,20000)
r1.cal_area#用了property这个装饰器之后,实例在调用函数属性就等于调用数据属性,不用加()就可以调用
r2.cal_area C:\python35\python3.exe D:/pyproject/day25/静态属性.py 北爷 住的厕所 总面积是4平米的地下室 喵爷 住的北京 总面积是1200平米的地下室

5、这样还不行。因为正常的数据属性直接运行是没有返回值的

6、现在改为了直接return一个返回值,现在用起来的效果就是跟调用数据属性是一模一样的了,property这个装饰器就是把类的函数属性变为数据属性,也就是封装成了数据属性

class Room:
def __init__(self,name,ower,width,length,heigh):
self.Name=name
self.Ower=ower
self.Width=width
self.Length=length
self.Heigh=heigh
@property #把一个方法变成一个数据属性
def cal_area(self):
# print("%s 住的%s 总面积是%s平米的地下室" %(self.Ower, self.Name, self.Width * self.Length))
# return (self.Width * self.Length)
return "%s 住的%s 总面积是%s平米的地下室" % (self.Ower, self.Name, self.Width * self.Length)
r1=Room("厕所","北爷",2,2,20000)#实例化出来一个实例r1,实例化的过程就是执行__init__
r2=Room("北京","喵爷",20,60,20000)
print(r1.cal_area)#用了property这个装饰器之后,实例在调用函数属性就等于调用数据属性,不用加()就可以调用
print(r2.cal_area)
print(r1.Name)#调用r1这个实例的数据属性
print(r2.Name)#调用r2这个实例的数据属性 C:\python35\python3.exe D:/pyproject/day25/静态属性.py 北爷 住的厕所 总面积是4平米的地下室 喵爷 住的北京 总面积是1200平米的地下室 厕所 北京

7、算是完美了,我们在增加一个计算体积的,当做是练习一下

class Room:
def __init__(self,name,ower,width,length,heigh):
self.Name=name
self.Ower=ower
self.Width=width
self.Length=length
self.Heigh=heigh
@property #把一个方法变成一个数据属性
def cal_area(self):
# print("%s 住的%s 总面积是%s平米的地下室" %(self.Ower, self.Name, self.Width * self.Length))
# return (self.Width * self.Length)
return "%s 住的%s 总面积是%s平米的地下室" % (self.Ower, self.Name, self.Width * self.Length)
@property
def cal_tiji(self):
return "%s 住的%s 总体积是%s平米的地下室" % (self.Ower, self.Name, self.Width * self.Length * self.Heigh)
r1=Room("厕所","北爷",2,2,20000)#实例化出来一个实例r1,实例化的过程就是执行__init__
r2=Room("北京","喵爷",20,60,20000)
r3=Room("西安","修电脑",20,60,20000)
print(r1.cal_area)#用了property这个装饰器之后,实例在调用函数属性就等于调用数据属性,不用加()就可以调用
print(r2.cal_area)
print(r3.cal_tiji) C:\python35\python3.exe D:/pyproject/day25/静态属性.py 北爷 住的厕所 总面积是4平米的地下室 喵爷 住的北京 总面积是1200平米的地下室 修电脑 住的西安 总体积是24000000平米的地下室

二、类方法

1、类是怎么调用自己的数据属性呢

class Room:
tag=1#定义一个类的数据属性
def __init__(self,name,ower,width,length,heigh):
self.Name=name
self.Ower=ower
self.Width=width
self.Length=length
self.Heigh=heigh
@property #把一个方法变成一个数据属性
def cal_area(self):
return "%s 住的%s 总面积是%s平米的地下室" % (self.Ower, self.Name, self.Width * self.Length)
@property
def cal_tiji(self):
return "%s 住的%s 总体积是%s平米的地下室" % (self.Ower, self.Name, self.Width * self.Length * self.Heigh)
print(Room.tag) C:\python35\python3.exe D:/pyproject/day25/静态属性.py 1

2、由于self把类和实例绑定到一起了,所以我们的折中方案就是先生成一个实例,然后在用类去调用方法,把实例手动穿进去

class Room:
tag=1#定义一个类的数据属性
def __init__(self,name,ower,width,length,heigh):
self.Name=name
self.Ower=ower
self.Width=width
self.Length=length
self.Heigh=heigh
def tell_info(self):
print("---->",self.tag)
r1 = Room("厕所", "北爷", 2, 2, 20000)
Room.tell_info(r1)#类调用类的函数属性的时候需要手动传实例本身 C:\python35\python3.exe D:/pyproject/day25/静态属性.py 1 ----> 1

3、但是我如果只想执行类的方法,不想跟任何实例有捆绑,该怎么做呢,python给我们提供了classmethod这个装饰器,只要用了这个方法, 就表示这个装饰器下面的方法是专门给类用的

这个方法就是只是类在调用类的方法,跟实例没关系,只要加了classmethod就只能供类调用

class Room:
tag=1#定义一个类的数据属性
def __init__(self,name,ower,width,length,heigh):
self.Name=name
self.Ower=ower
self.Width=width
self.Length=length
self.Heigh=heigh
@classmethod#这个装饰器是专门供类使用的方法
def tell_info(cls):#cls代表类本身
print(cls)
print("---",cls.tag)#等价于Room.tag
Room.tell_info()#会自动把类本身传给cls C:\python35\python3.exe D:/pyproject/day25/静态属性.py <class '__main__.Room'> --- 1

三、静态方法 叫类的工具包,不跟类绑定也不跟实例绑定

class Room:
tag=1#定义一个类的数据属性
def __init__(self,name,ower,width,length,heigh):
self.Name=name
self.Ower=ower
self.Width=width
self.Length=length
self.Heigh=heigh
@classmethod#这个装饰器是专门供类使用的方法
def tell_info(cls):#cls代表类本身
print(cls)
print("---",cls.tag)
@staticmethod#静态方法 叫类的工具包,不跟类绑定也不跟实例绑定
def wash_body(a,b,c):
print("%s %s %s 正在洗澡" %(a,b,c))
Room.wash_body("北爷","喵爷","修电脑")#用类调用washbody这个方法
r1=Room("厕所","北爷",2,2,20000)#实例化一个实例r1
r1.wash_body("北爷","喵爷","修电脑")#用实例调用washbody这个方法 C:\python35\python3.exe D:/pyproject/day25/静态方法.py 北爷 喵爷 修电脑 正在洗澡 北爷 喵爷 修电脑 正在洗澡

查看下 这个静态方法是不是存到了类的属性字典里面

class Room:
tag=1#定义一个类的数据属性
def __init__(self,name,ower,width,length,heigh):
self.Name=name
self.Ower=ower
self.Width=width
self.Length=length
self.Heigh=heigh
@classmethod#这个装饰器是专门供类使用的方法
def tell_info(cls):#cls代表类本身
print(cls)
print("---",cls.tag)
@staticmethod#静态方法 叫类的工具包,不跟类绑定也不跟实例绑定
def wash_body(a,b,c):
print("%s %s %s 正在洗澡" %(a,b,c))
Room.wash_body("北爷","喵爷","修电脑")#用类调用washbody这个方法
print(Room.__dict__)#查看下静态方法 结果是定义到了类的属性字典里面了

总结:

静态属性:property类和实例都可以访问静态属性

(把函数封装成一个数据属性,让外面的人感受不  到是调用的函数属性)

类方法:  classmethod只能类访问类方法,不能用实例访问类方法

静态方法:staticmethod 用类可以调用静态方法,实例也可以调用静态方法

不跟类和实例绑定,只叫类的工具包

python的类的 静态属性 类方法 静态方法的更多相关文章

  1. python - class类 (二) 静态属性/类方法/静态方法

    静态属性: #静态属性 = 数据属性 (@property) class mianji(): def __init__(self,x,y): self.x = x self.y = y #类的函数方法 ...

  2. JS面向对象(3) -- Object类,静态属性,闭包,私有属性, call和apply的使用,继承的三种实现方法

    相关链接: JS面向对象(1) -- 简介,入门,系统常用类,自定义类,constructor,typeof,instanceof,对象在内存中的表现形式 JS面向对象(2) -- this的使用,对 ...

  3. Class的使用,构造方法,实例属性和实例方法,静态属性和静态方法,this和super关键字,类的继承

    s6新增了一种定义对象实例的方法,Class(类)这个概念,作为对象的模板.class可以看作只是一个语法糖,通过class关键字,可以定义类.让对象原型的写法更加清晰.更像面向对象编程的语法. 一. ...

  4. PHP中的抽象类与抽象方法/静态属性和静态方法/PHP中的单利模式(单态模式)/串行化与反串行化(序列化与反序列化)/约束类型/魔术方法小结

      前  言  OOP  学习了好久的PHP,今天来总结一下PHP中的抽象类与抽象方法/静态属性和静态方法/PHP中的单利模式(单态模式)/串行化与反串行化(序列化与反序列化). 1  PHP中的抽象 ...

  5. PHP static静态属性和静态方法

    这里分析了php面向对象中static静态属性和静态方法的调用.关于它们的调用(能不能调用,怎么样调用),需要弄明白了他们在内存中存放位置,这样就非常容易理解了.静态属性.方法(包括静态与非静态)在内 ...

  6. php面向对象中static静态属性和静态方法的调用

    这篇文章主要介绍了php面向对象中static静态属性和静态方法的调用,实例分析了static静态属性和静态方法的原理与调用技巧,需要的朋友可以参考下 本文实例讲述了php中static静态属性和静态 ...

  7. php静态属性和静态方法

    php静态属性和静态方法 2012-09-29 10:18 1518人阅读 评论(0) 收藏 举报 phpfunction 本php教程主要是学习php中静态属性和静态方法的使用方法和基本的示例. · ...

  8. static静态属性和静态方法的原理与调用技巧

    这篇文章主要介绍了php面向对象中static静态属性和静态方法的调用,实例分析了static静态属性和静态方法的原理与调用技巧,需要的朋友可以参考下     本文实例讲述了php中static静态属 ...

  9. PHP使用static关键字声明静态属性和静态方法

    PHP使用static关键字声明静态属性和静态方法 在PHP中,通过static关键字修饰的成员属性和成员方法被称为静态属性和静态方法. 静态属性和静态方法不需要在被类实例化的情况下就可以直接使用. ...

随机推荐

  1. Scala学习(一)--Scala基础学习

    Scala基础学习 摘要: 在篇主要内容:如何把Scala当做工业级的便携计算器使用,如何用Scala处理数字以及其他算术操作.在这个过程中,我们将介绍一系列重要的Scala概念和惯用法.同时你还将学 ...

  2. JS关闭窗口而不提示

    使用js关闭窗口而不提示代码: window.opener = null; window.open( '', '_self' ); window.close();

  3. 部署AlwaysOn第三步:集群资源组的健康检测和故障转移

    资源组是由一个或多个资源组成的组,WSFC的故障转移是以资源组为单位的,资源组中的资源是相互依赖的.一个资源所依赖的其他资源必须和该资源处于同一个资源组,跨资源组的依赖关系是不存在的.在任何时刻,每个 ...

  4. STM8S——8位基本定时器(TIM4)

    简介:该定时器由一个带可编程预分频器的8位自动重载的向上计数器所组成,它可以用来作为时基发生器,具有溢出中断功能. 主要功能: (1)8位向上计数的自动重载计数器: (2)3位可编程的预分配器(可在运 ...

  5. 网易云易盾朱星星:最容易被驳回的10大APP过检项

    本文由  网易云发布. 1月20日,“走进网易:移动测试与安全实践”公开活动在杭州西湖区颐高创业大厦4F楼友会创业咖啡厅举行.本次活动的议题聚焦在如何实现应用的高效开发.安全过检.开发功耗降到最低等热 ...

  6. Hugepage介绍以及实践

    在Linux 64位系统里面,默认内存是以4K的页面(Page)来管理的,当系统有非常多的内存的时候,管理这些内存的消耗就比较大;而HugePage使用2M大小的页面来减小管理开销. Hugepage ...

  7. 团队作业(五)-笔记app top5

    在互联网快速发展的情况下,各个行业的软件层出不穷,五花八门.各个行业都有相当多的软件介入其中,在如此多的软件之中,便有了相当激烈的竞争角逐.今天我们十五万的总冠军就着笔记APP行业中位列top 5的软 ...

  8. 关于vue-eslint自动补全代码,以及自动生成雪碧图

    一.配置eslint module.exports={ "printWidth": 240, //一行的字符数,如果超过会进行换行,默认为80 "tabWidth&quo ...

  9. MySQL基础(二):视图、触发器、函数、事务、存储过程

    一.视图 视图是一个虚拟表(非真实存在),其本质是[根据SQL语句获取动态的数据集,并为其命名],用户使用时只需使用[名称]即可获取结果集,并可以将其当作表来使用. 视图和上一篇学到的临时表搜索类似. ...

  10. BZOJ 4242 水壶(BFS建图+最小生成树+树上倍增)

    题意 JOI君所居住的IOI市以一年四季都十分炎热著称. IOI市是一个被分成纵H*横W块区域的长方形,每个区域都是建筑物.原野.墙壁之一.建筑物的区域有P个,编号为1...P. JOI君只能进入建筑 ...