Python中C++类特性的实现原理

<span style="font-size:18px;">#python类的特性</span>
<span style="font-size:18px;">#而且python还可以实现函数的重载,通过不同的参数来做不同的内部实现</span>
<span style="font-size:18px;">#def overload(*args):</span>
<span style="font-size:18px;">#<span style="white-space:pre">	</span>def overload1():</span>
<span style="font-size:18px;">#<span style="white-space:pre">		</span>print("No args")</span>
<span style="font-size:18px;">#<span style="white-space:pre">	</span>def overload2(x):</span>
<span style="font-size:18px;">#<span style="white-space:pre">		</span>print("one args")</span>
<span style="font-size:18px;">#<span style="white-space:pre">	</span>def overload3(x,y):</span>
<span style="font-size:18px;">#<span style="white-space:pre">		</span>print("two args")</span>
<span style="font-size:18px;">#<span style="white-space:pre">	</span>if len(args) == 0:</span>
<span style="font-size:18px;">#<span style="white-space:pre">		</span>overload1()</span>
<span style="font-size:18px;">#<span style="white-space:pre">	</span>elif len(args) == 1:</span>
<span style="font-size:18px;">#<span style="white-space:pre">		</span>overload2(*args)</span>
<span style="font-size:18px;">#<span style="white-space:pre">	</span>else len(args) == 2:</span>
<span style="font-size:18px;">#<span style="white-space:pre">		</span>overload3(*args)</span>
<span style="font-size:18px;">
class Point:
    x = 100
    y = 200
    def __init__(self, *args):
        try:
            self.x = args[0]
            self.y = args[1]
        except ValueError, e:
            print(e.message)
        except IndexError, e:
            print(e.message)

    def trace(self):
        print 'x=%d y=%d' % (self.x, self.y)

    def overload(self):
        print('Point overload')

    def baseMethod(self):
        print('base method!!!!!!')

<strong><span style="color:#ff0000;">    #接口预留,本处没有实现doVirtual,经由子类来实现
    def delegate(self):
        self.doVirtual()</span></strong>

class Point3D(Point):
    z = 0
    def __init__(self, *args):
        try:
            Point.__init__(self, *args)
            self.z = args[2]
        except IndexError, e:
            print e.message

<strong><span style="color:#ff0000;">    #函数重写override
    def trace(self):
        Point.trace(self)
        print 'z=%d' % self.z</span></strong>

 <span style="color:#ff0000;"><strong>   #函数遮挡
    def overload(self, x):
        print('Point3D visible')</strong></span>

class PointProvider(Point):
    def __init__(self, *argc):
        Point.__init__(self, *argc)

    def doVirtual(self):
        print 'Implements doVirtual!'

if __name__ == '__main__':
    p1 = Point(10,20)
    p1.k=100 #变相的给增加了成员
    pk = 'p1.k=%d' % (p1.k)
    print(pk)
    p1.trace()

    p2 = Point(1,1)
    p2.overload()
    #compiler error!!!
    #print(p2.k)

    p = Point3D(1,2,3)
    p.trace()
    #看不见基类的overload了,必须要传入一个参数
    p.overload(100) 

    p2.baseMethod()

    pp = PointProvider(10,20)
    pp.delegate()</span>

所以综上所示:

python可以实现类的继承、重载、重写(多态)、函数覆盖(隐藏基类函数)

时间: 2024-11-02 11:43:40

Python中C++类特性的实现原理的相关文章

python 中的类

python 中的类内容概述类的概念: 类是一组方法与属性的抽象集. 属性 实例变量(每个实例内存中) 类变量(类内存中) 私有属性 __var 方法 构造方法 析构函数(默认就有,代码为空,写了则相当于重构它) 其他方法 对象(object):类的实例(实例化一个类之后得到的对象) 类的特性: 封装: 把一些功能的实现细节不对外暴露 继承: 继承顺序:(先覆盖.再继承.再添加) 继承:代码复用 继承方式: 单继承 多继承 2.7 经典类 深度优先 新式类 广度优先 3.x 均广度优先 多态:

Python中的类和方法使用举例

1.类的属性 成员变量对象的创建创建对象的过程称之为实例化,当一个对象被创建后,包含三个方面的特性对象聚丙属性和方法,句柄用于区分不同的对象,对象的属性和方法,与类中的成员变量和成员函数对应,obj = MyClass()创建类的一个实例,扩号对象,通过对象来调用方法和属性 类的属性 类的属性按使用范围分为公有属性和私有属性类的属性范围,取决于属性的名称,共有属性---在内中和内外都能够调用的属性私有属性---不能在内外贝类以外函数调用定义方式:以""双下划线开始的成员变量就是私有属性

对python中元类的理解

1. 类也是对象 在大多数编程语言中,类就是一组用来描述如何生成一个对象的代码段.在Python中这一点仍然成立: >>> class ObjectCreator(object): - pass - >>> my_object = ObjectCreator() >>> print my_object <__main__.ObjectCreator object at 0x8974f2c> 但是,Python中的类还远不止如此.类同样也是一

关于Python中的类普通继承与super函数继承

关于Python中的类普通继承与super函数继承 1.super只能用于新式类 2.多重继承super可以保公共父类仅被执行一次 一.首先看下普通继承的写法 二.再看看super继承的写法 参考链接:http://blog.csdn.net/lqhbupt/article/details/19631991

Python中的类(上)

在Python中,可以通过class关键字定义自己的类,然后通过自定义的类对象类创建实例对象. 例如,下面创建了一个Student的类,并且实现了这个类的初始化函数"__init__": class Student(object): count = 0 books = [] def __init__(self, name, age): self.name = name self.age = age pass 接下来就通过上面的Student类来看看Python中类的相关内容. 数据属性

简述Python中的类与对象

Python中的类 类的定义 示例: class Person: country = "China" def __init__(self, name, age): self.name = name self.age = age def speak(self, word): print(word) 其中 country 是类属性,即 Person类 的静态属性,speak() 为 Person类的函数属性,即类的动态属性~ 类的实例化 对上述示例的类进行实例化: >>>

python中新式类和经典类

python中的类分为新式类和经典类,具体有什么区别呢?简单的说, 1.新式类都从object继承,经典类不需要. Python 2.x中默认都是经典类,只有显式继承了object才是新式类 Python 3.x中默认都是新式类,不必显式的继承object 2.经典类继承深度优先,新式类继承广度优先. 在多重继承关系下,子类的实例对象想要调用父类的方法,向上寻找时的顺序. 3.新式类相同父类只执行一次构造函数,经典类重复执行多次. class A: def __init__(self): pri

python进阶三(面向对象编程基础)【3-1 python中创建类属型】

python中创建类属性 类是模板,而实例则是根据类创建的对象. 绑定在一个实例上的属性不会影响其他实例,但是,类本身也是一个对象,如果在类上绑定一个属性,则所有实例都可以访问类的属性,并且,所有实例访问的类属性都是同一个!也就是说,实例属性每个实例各自拥有,互相独立,而类属性有且只有一份. 定义类属性可以直接在 class 中定义: 1 class Person(object): 2 address = 'Earth' 3 def __init__(self, name): 4 self.na

使用C语言为python编写动态模块(3)--在C中实现python中的类

楔子 这次我们来介绍python中的类型在C中是如何实现的,我们在C中创建python的int对象,可以使用PyLong_FromLong.创建python的list对象可以使用PyList_New,那么如何在C中构建一个python中的类呢? 对于构建一个类,我们肯定需要以下步骤: 创建一个类扩展 添加类的参数 添加类的方法 添加类的属性,比如可以设置.获取属性 添加类的继承 解决类的循环引用导致的内存泄露问题和自定义垃圾回收 前面几个步骤是必须的,但是容易把最后一个问题给忽略掉.我们在pyt