python同样支持类和对象。在python3.x中没有了经典类,只有新式类,默认创建的就是新式类。具体的新式类与经典类的不同在python3.x中已经没有意义了。

  类的定义和实例化

  python定义简单类如下。

class Car(object):
pass c1=Car()

  我们定义了一个Car类,其中什么方法也没有实现。c1是我们实例化的类Car,成为对象。

  静态变量

  我们可以在类中定义静态变量,静态变量属于类,既可以使用类访问,也可以使用对象访问。

class Car(object):
type='car' c1=Car()
print(c1.type)
print(Car.type)

  运行结果是:

car
car

  动态变量

  动态变量属于类,在第一次创建类的时候传入类中。动态变量只属于对象,只能由对象访问。

class Car(object):
type='car' def __init__(self, name, colour):
self.name = name
self.colour = colour
print('我被创建了。') c1=Car('Lamborghini','yellow')
print(c1.type)
print(Car.type)
print('name:%s,colour:%s'%(c1.name,c1.colour))

  运行结果是:

我被创建了。
car
car
name:Lamborghini,colour:yellow

  类被创建的时候就会访问__init__()方法,上面的类__init__方法中请求了两个参数,所以创建的时候就必须要传入两个传输,其中self的意思是对象本身,以本例来说,当创建Car的实例c1时,self就是c1。

  因为作用域的原因,传入的两个参数只能在__init__()中使用,如果想要在其它地方调用,就需要将值传给self。而这个参数就被称为动态参数。

  动态方法

  类的动态方法是自定义的方法,同时只有对象能够调用。

class Car(object):
type='car' def __init__(self, name, colour):
self.name = name
self.colour = colour
print('我被创建了。')
def show(self):
print("The car's name is %s and colour is %s." % (self.name, self.colour)) c1=Car('Lamborghini','yellow')
print(c1.type)
print(Car.type)
print('name:%s,colour:%s'%(c1.name,c1.colour))
c1.show()

  运行结果是:

我被创建了。
car
car
name:Lamborghini,colour:yellow
The car's name is Lamborghini and colour is yellow.

  show()就是类的动态方法。

  静态方法

  有动态方法必然会有静态方法。静态方法属于类,类和对象都可以进行调用。

class Car(object):
@staticmethod
def description():
print('This is a very fast car.') c1=Car()
c1.description()
Car.description()

  静态方法的写法就是在动态方法前加入装饰器,并且不传入self参数。

  类的属性

  在方法前面加入@property装饰器,这个方法就变成了类的属性,可以以调用属性的方式进行方法的调用。

class Car(object):
def __init__(self, name, colour):
self.name = name
self.colour = colour
@property
def show(self):
print("The car's name is %s and colour is %s." % (self.name, self.colour)) c1=Car('Lamborghini','yellow')
c1.show

  运行结果是:

The car's name is Lamborghini and colour is yellow.

  可见,运行的时候不需要添加括号。

  私有变量

  在变量前面加入两个下划线就将这个变量变为了私有变量,创建的对象没有变法访问私有变量,私有变量只能内部访问。那么私有变量怎么显示呢?

class Car(object):
def __init__(self, name, colour):
self.__name = name
self.__colour = colour
def show(self):
print("The car's name is %s and colour is %s." % (self.__name, self.__colour)) c1=Car('Lamborghini','yellow')
c1.show()

  运行结果是:

The car's name is Lamborghini and colour is yellow.

  私有变量能在类内部定义方法进行读取。

  利用类的特性也可以访问私有字段。

lass Car(object):
def __init__(self, name, colour):
self.__name = name
self.__colour = colour
def show(self):
print("The car's name is %s and colour is %s." % (self.__name, self.__colour))
@property
def name(self):
return self.__name c1=Car('Lamborghini','yellow')
c1.show()
print(c1.name)

  运行结果是:

The car's name is Lamborghini and colour is yellow.
Lamborghini

  通过设定和私有字段相似的名称的特性名称,从程序外部看来就好像是访问了私有字段一样,这种方法也是可以访问私有字段的。

  私有方法

  将方法前面加上两个下划线就会变成私有方法,外部就无法访问这个方法了。而如果要访问这个方法只能在类的内部才可以访问。

class Car(object):
def __init__(self, name, colour):
self.__name = name
self.__colour = colour
def __show(self):
print("The car's name is %s and colour is %s." % (self.__name, self.__colour))
def func(self):
self.__show() c1=Car('Lamborghini','yellow')
c1.func()

  运行结果是:

The car's name is Lamborghini and colour is yellow.

  私有方法也可以使用以下方法进行调用,但是并不建议这样使用。

class Car(object):
def __init__(self, name, colour):
self.__name = name
self.__colour = colour
def __show(self):
print("The car's name is %s and colour is %s." % (self.__name, self.__colour))
def func(self):
self.__show() c1=Car('Lamborghini','yellow')
c1._Car__show()

  运行结果是:

The car's name is Lamborghini and colour is yellow.

  私有变量更改

  如果我们必须更改私有变量呢?其实也是有办法的,可以使用以下的方法。

class Car(object):
def __init__(self, name, colour):
self.__name = name
self.__colour = colour
def show(self):
print("The car's name is %s and colour is %s." % (self.__name, self.__colour))
@property
def func(self):
return self.__name
@func.setter
def func(self,value):
self.__name=value c1=Car('Lamborghini','yellow')
c1.show()
c1.func='car'
c1.show()

  运行结果是:

The car's name is Lamborghini and colour is yellow.
The car's name is car and colour is yellow.

  这样就实现了私有变量的更改的操作

  析构函数

  __init__()在对象被创建的时候进行调用,成为构造函数。而对象被销毁的时候就会调用__del__()函数,成为析构函数。

class Car(object):
def __init__(self):
print('我被创建了')
def __del__(self):
print('我要被销毁了') c1=Car()

  运行结果是:

我被创建了
我要被销毁了

  __call__方法

  python中也有一个方法叫做__call__(),这个方法是干什么用的呢?当对象作为一个函数进行执行的时候,就会执行这个方法。

class Car(object):
def __call__(self, *args, **kwargs):
print('call') c1=Car()
c1()

  运行结果是:

call

  可以看到使用这个方法之后,对象就能添加括号直接进行执行了。

  

python3.x 类和对象的更多相关文章

  1. (08)-Python3之--类和对象

    1.定义 类:类是抽象的,一类事物的共性的体现.  有共性的属性和行为. 对象:具体化,实例化.有具体的属性值,有具体做的行为. 一个类 对应N多个对象. 类包含属性以及方法. class 类名: 属 ...

  2. python3 类、对象的基础概念

    类:具有相同特性和方法的抽象概念称为类 对象:从类中具体描述的一个事物称为对象 类和对象的关系:类是对象的抽象概念,对象是类的具体实例 class test001: #创建类 def __init__ ...

  3. day24:面向对象设计与面向对象编程、类和对象

    一.三大编程范式: 面向过程: 面向函数: 面向对象: 二.程序的进化论: 1.编程最开始就是无组织无结构,从简单控制流中按步写指令 2.从上述的指令中提取重复的代码块或逻辑,组织到一起(比方说,你定 ...

  4. python的类和对象——进阶篇

    写在前面的话 终于,又到了周五.当小伙伴们都不再加班欢欢喜喜过周末的时候,我刚刚写完这一周的游戏作业,从面对晚归的紧皱眉头到现在的从容淡定,好像只有那么几周的时间.突然发现:改变——原来这么简单.很多 ...

  5. python 面向对象之封装与类与对象

    封装 一,引子 从封装本身的意思去理解,封装就好像是拿来一个麻袋,把小猫,小狗,小王八,小老虎一起装进麻袋,然后把麻袋封上口子.照这种逻辑看,封装='隐藏',这种理解是相当片面的 二,先看如何隐藏 在 ...

  6. python 类和对象

    类和对象 类 1.类的组成    数据和函数,二者是类的属性 2.两个作用: 实例化 属性引用  属性引用:类名.属性(增删改查)   实例化: 类名加括号就是实例化,会自动出发__init__的运行 ...

  7. Python类和对象

    目录 类与对象 其他方法 继承 经典类和新式类 派生 组合 接口.归一化设计与抽象类 继承实现的原理 子类中调用父类的方法 指名道姓 super()方法 多态与多态性 封装 单下划线开头 双下划线开头 ...

  8. Python深入类和对象

    一. 鸭子类型和多态 1.什么是鸭子类型: 在程序设计中,鸭子类型(英语:Duck typing)是动态类型和某些静态语言的一种对象推断风格."鸭子类型"像多态一样工作,但是没有继 ...

  9. python的类和对象

    一.面向对象和面向过程 1.1面向过程的特点 优点是:极大的降低了写程序的复杂度,只需要顺着要执行的步骤,堆叠代码即可. 缺点是:一套流水线或者流程就是用来解决一个问题,代码牵一发而动全身. 1.2面 ...

随机推荐

  1. javascript闭包和立即执行函数的作用

    一.闭包——closure 先看一个闭包的例子.我们想实现一个计数器,最简单的方法就是定义一个全局变量,计数的时候将其加1.但是全局变量有风险,哪里都有可能不小心改掉它.那局部变量呢, 它只在函数内部 ...

  2. ClipboardJS的坑,

    new 一下构造函数就出错了,为什么...Uncaught TypeError: Cannot read property 'addEventListener' of nullat r (clipbo ...

  3. mysql 命令行导数据库

    cd  d: 然后应该会提示你已经进入D盘了,按照你数据库的地址,我的数据库是在D盘的wamp这个文件夹目录, 输入命令:cd ruanjian\mysql\bin     类似于这样,大家可以先在本 ...

  4. LR简单解析

  5. vs 2017 保存文件 utf8

    vs 2017 保存文件 utf8 转自:https://blog.csdn.net/jiegemena/article/details/79369650

  6. Neutron三层网络服务实现原理

    Neutron 对虚拟三层网络的实现是通过其 L3 Agent (neutron-l3-agent).该 Agent 利用 Linux IP 栈.route 和 iptables 来实现内网内不同网络 ...

  7. ASP.NET MVC 路由系统类

    RouteData public class RouteData { private RouteValueDictionary _dataTokens; private IRouteHandler _ ...

  8. SqlServer中存储过程 returnC#代码处理以及对应的MySQL如何改写

    一.SqlServer 中 1. 创建表 create table testuser( id int, --primary key, names ), address ), paw ) ) 2.创建存 ...

  9. MySQL pt-table-checksum及pt-table-sync校验及修复主从一致性

    [pt-table-checksum]pt-table-checksum是percona-toolkit系列工具中的一个, 可以用来检测主. 从数据库中数据的一致性.其原理是在主库上运行, 对同步的表 ...

  10. 二进制包形式安装mysql5.7.17

    mysql5.7与mysql5.5的安装方式有些区别,如果按照5.5的方式来安装5.7就会有很多报错信息,下面介绍mysql5.7.17的二进制安装方式. 首先安装依赖包: yum -y instal ...