python调用c++类内静态函数_【引用】python 静态函数 类函数 实例函数

1.关于定义类的一些奇特之处

今天在Python中定义一个类,很奇怪,不需要事先声明它的成员变量吗?暂时不知,先记录下来:

f0cd6c7f9e7ae96feae062cb48f670f0.pngclass Account(object):

f0cd6c7f9e7ae96feae062cb48f670f0.png    "一个简单的类"

f0cd6c7f9e7ae96feae062cb48f670f0.png    account_type="Basic"

f0cd6c7f9e7ae96feae062cb48f670f0.png    def __init__(self,name,balance):

f0cd6c7f9e7ae96feae062cb48f670f0.png        "初始化一个新的Account实例"

f0cd6c7f9e7ae96feae062cb48f670f0.png        self.name=name

f0cd6c7f9e7ae96feae062cb48f670f0.png        self.balance=balance

f0cd6c7f9e7ae96feae062cb48f670f0.png    def deposit(self,amt):

f0cd6c7f9e7ae96feae062cb48f670f0.png        "存款"

f0cd6c7f9e7ae96feae062cb48f670f0.png        self.balance=self.balance+amt

f0cd6c7f9e7ae96feae062cb48f670f0.png    def withdraw(self,amt):

f0cd6c7f9e7ae96feae062cb48f670f0.png        "取款"

f0cd6c7f9e7ae96feae062cb48f670f0.png        self.balance=self.balance-amt

f0cd6c7f9e7ae96feae062cb48f670f0.png    def inquiry(self):

f0cd6c7f9e7ae96feae062cb48f670f0.png        "返回当前余额"

f0cd6c7f9e7ae96feae062cb48f670f0.png        return self.balance

其中,__init__函数就是Python中的构造函数吧?另外,balance这个变量没有在类中定义,却直接拿来使用,虽然说脚本语言可以预先不定义变量,但是在类中,定义一下是不是可以使类更清晰呢?

另外,在python中类中定义成员函数一般第一个参数总是self,表示自已的实例,与C++中的this指针差不多,不过C++中的this指针是隐函于其中并全局可见的,而在Python中却要作为参数传进去, 这是Python中定义类的另一个特点。

还有一个特点,在类的成员函数中,使用类中的另一个成员函数,前面必须要指定类名,如下:

f0cd6c7f9e7ae96feae062cb48f670f0.png class Foo(object):

f0cd6c7f9e7ae96feae062cb48f670f0.png     def bar(self):

f0cd6c7f9e7ae96feae062cb48f670f0.png         print "bar!"

f0cd6c7f9e7ae96feae062cb48f670f0.png     def spam(self):

f0cd6c7f9e7ae96feae062cb48f670f0.png         bar(self)     # 错误,引发NameError

f0cd6c7f9e7ae96feae062cb48f670f0.png         Foo.bar(self) # 合法的

f0cd6c7f9e7ae96feae062cb48f670f0.png

2.在类中声明静态方法并使用静态方法

要在类中使用静态方法,[email protected],[email protected]�的好处是,不需要定义实例即可使用这个方法:另外,多个实例共享此静态方法,如下:

f0cd6c7f9e7ae96feae062cb48f670f0.pngclass SimClass():

f0cd6c7f9e7ae96feae062cb48f670f0.png   @staticmethod

f0cd6c7f9e7ae96feae062cb48f670f0.png   def ShareStr():

f0cd6c7f9e7ae96feae062cb48f670f0.png      print "This is a static Method"

f0cd6c7f9e7ae96feae062cb48f670f0.png

f0cd6c7f9e7ae96feae062cb48f670f0.png

f0cd6c7f9e7ae96feae062cb48f670f0.pngSimClass.ShareStr()   #使用静态函数

3.类方法:

类方法与普通的成员函数和静态函数有不同之处,在接触的语言中好像也没见过这种语义,看它的定义:

一个类方法就可以通过类或它的实例来调用的方法, 不管你是用类来调用这个方法还是类实例调用这个方法,该方法的第一个参数总是定义该方法的类对象。

记住:方法的第一个参数都是类对象而不是实例对象.

按照惯例,类方法的第一个形参被命名为 cls. 任何时候定义类方法都不是必须的(类方法能实现的功能都可以通过定义一个普通函数来实现,只要这个函数接受一个类对象做为参数就可以了).

定义类方法并使用类方法:

f0cd6c7f9e7ae96feae062cb48f670f0.pngclass ABase(object):

f0cd6c7f9e7ae96feae062cb48f670f0.png    @classmethod        #类方法修饰符

f0cd6c7f9e7ae96feae062cb48f670f0.png    def aclassmet(cls): print ‘a class method for‘, cls.__name__

f0cd6c7f9e7ae96feae062cb48f670f0.pngclass ADeriv(ABase): pass

f0cd6c7f9e7ae96feae062cb48f670f0.pngbInstance = ABase(  )

f0cd6c7f9e7ae96feae062cb48f670f0.pngdInstance = ADeriv(  )

f0cd6c7f9e7ae96feae062cb48f670f0.pngABase.aclassmet(  )               # prints: a class method for ABase

f0cd6c7f9e7ae96feae062cb48f670f0.pngbInstance.aclassmet(  )           # prints: a class method for ABase

f0cd6c7f9e7ae96feae062cb48f670f0.pngADeriv.aclassmet(  )              # prints: a class method for ADeriv

f0cd6c7f9e7ae96feae062cb48f670f0.pngdInstance.aclassmet(  )           # prints: a class method for ADeriv

也就是说,类方法并不是必须的,使用普通函数也可以实现类方法的功能。

4.类的继承

在python中,继承一个类,就像这样:

class A(object)  #继承object类

#.......

class B(A)         #继承A类

#........

另外,python中支持多继承,对于多继承,找某个对应的函数,其python有相应的方法,如:

f0cd6c7f9e7ae96feae062cb48f670f0.png class D(oject): pass                    #D继承自object

f0cd6c7f9e7ae96feae062cb48f670f0.png    class B(D):                             #B是D的子类

f0cd6c7f9e7ae96feae062cb48f670f0.png        varB = 42

f0cd6c7f9e7ae96feae062cb48f670f0.png        def method1(self):

f0cd6c7f9e7ae96feae062cb48f670f0.png            print "Class B : method1"

f0cd6c7f9e7ae96feae062cb48f670f0.png    class C(D):                             #C也是D的子类

f0cd6c7f9e7ae96feae062cb48f670f0.png        varC = 37

f0cd6c7f9e7ae96feae062cb48f670f0.png        def method1(self):

f0cd6c7f9e7ae96feae062cb48f670f0.png            print "Class C : method1"

f0cd6c7f9e7ae96feae062cb48f670f0.png       def method2(self):

f0cd6c7f9e7ae96feae062cb48f670f0.png           print "Class C : method2"

f0cd6c7f9e7ae96feae062cb48f670f0.png   class A(B,C):                           #A是B和C的子类

f0cd6c7f9e7ae96feae062cb48f670f0.png       varA = 3.3

f0cd6c7f9e7ae96feae062cb48f670f0.png       def method3(self):

f0cd6c7f9e7ae96feae062cb48f670f0.png          print "Class A : method3"

f0cd6c7f9e7ae96feae062cb48f670f0.png

如果我要调用A.method1() ,会出现什么结果?答案是ClassB:method1. 书上是只样介绍的:

当搜索在基 类中定义的某个属性时,Python采用深度优先的原则、按照子类定义中的基类顺序进行搜索。**注意**(new-style类已经改变了这种行为)。 上边例子中,如果访问 A.varB ,就会按照A-B-D-C-D这个顺序进行搜索,只要找到就停止搜索.若有多个基类定义同一属性的情况,则只使用第 一个被找到属性值:

5.数据隐藏

在python中实现数据隐藏很简单,不需要在前面加什么关键字,只要把类变量名或成员函数前面加两个下划线即可实现数据隐藏的功能,这样,对于类 的实例来说,其变量名和成员函数是不能使用的,对于其类的继承类来说,也是隐藏的,这样,其继承类可以定义其一模一样的变量名或成员函数名,而不会引起命 名冲突(也就是: "双下划线" 开始的是私有成员,意思是只有类对象自己能访问,连子类对象也不能访问到这个数据)。

f0cd6c7f9e7ae96feae062cb48f670f0.png class A:

f0cd6c7f9e7ae96feae062cb48f670f0.png       def __init__(self):

f0cd6c7f9e7ae96feae062cb48f670f0.png          self.__X = 3        # self._A__X

f0cd6c7f9e7ae96feae062cb48f670f0.png    

f0cd6c7f9e7ae96feae062cb48f670f0.png    class B(A):

f0cd6c7f9e7ae96feae062cb48f670f0.png       def __init__(self):

f0cd6c7f9e7ae96feae062cb48f670f0.png          A.__init__(self)

f0cd6c7f9e7ae96feae062cb48f670f0.png          self.__X = 37       # self._B__X

原文:http://www.cnblogs.com/Simon-xm/p/3890941.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值