Self 参数详解

来自linux中国网wiki
(重定向自Self参数详解
跳到导航 跳到搜索

  在Python中,定义类是通过class关键字,class后面紧接着是类名,类名通常是大写开头的单词,紧接着是('要继承的类名'),表示该类是从哪个类继承下来的,可以有多个父类(基类),通常如果没有合适的继承类,就使用object类,这是所有类最终都会继承的类,也可以不写。

class F1(object):  
    def __init__(self,name,age):  
        self.name = name 
        self.age = age
     
f1 = F1('python',27) 

这里注意:(1)、__init__方法的第一参数永远是self,表示创建的类实例本身,因此,在__init__方法内部,就可以把各种属性绑定到self,因为self就指向创建的实例本身。
(2)、有了__init__方法,在创建实例的时候,就不能传入空的参数了,必须传入与__init__方法匹配的参数,但self不需要传,Python解释器会自己把实例变量传进去
--------------------- 


  

上面的这个__init__()叫做初始化方法(或构造方法), 在类实例化时,这个方法(虽然它是函数形式,但在类中就不叫函数了,叫方法)会自动执行,
进行一些初始化的动作,所以我们这里写的__init__(self,name,age)就是要在创建一个角色时给它设置这些属性。 参数self有什么用呢?

1.在内存中开辟一块空间指向f1这个变量名 2.实例化F1这个类首先执行其中的__init__()方法,相当于F1.__init__(f1,'python',27),是为了把'python',27这2个值跟刚开辟的f1关联起来,因为关联起来后,你就可以直接f1.name, f1.age 这样来调用啦。所以,为实现这种关联,在调用__init__方法时,就必须把f1这个变量也传进去,否则__init__不知道要把那2个参数跟谁关联,self其实就是实例化对象f1被当作参数传递了。 3.所以这个__init__(…)构造方法里的,self.name = name , self.age = age 等等就是要把这几个值存到f1的内存空间里。


在Python中,类的方法与普通的函数有一个特别的区别——它们必须有一个额外的第一个参数名称,但是在调用这个方法的时候你不为这个参数赋值,Python会提供这个值。这个特别的变量指对象本身,按照惯例它的名称是self。 虽然你可以给这个参数任何名称,但是强烈建议你使用self这个名称——其他名称都是不赞成你使用的。 使用一个标准的名称有很多优点——你的程序读者可以迅速识别它,如果使用self的话,还有些IDE(集成开发环境)也可以帮助你。 给C++/Java/C#程序员的注释Python中的self等价于C++中的self指针和Java、C#中的this参考。

#!/usr/bin/python
#-*- coding:utf-8 -*-
#创建实例类Test
class Test(object):

    def add(self, a,b):
        打印输出a +b 的值 
        print (a + b)

    def display(self):
         打印出字符串
        print 'hello'

test = Test()
test.add(1,3) #调用方法
test.display()

def addTwo(a,b):
    print (a + b)

addTwo(1,2)    
  
4
hello
3
 

声明add()方法时,若不加self,则提示 
Traceback (most recent call last):
  File "selff.py", line 15, in <module>
    test.add(1,3) #调用方法
TypeError: add() takes exactly 2 arguments (3 given)

总结: self
1.self在Python里不是关键字。self代表当前对象的地址。
2.跟java与C++中的this指针作用相似,但是区别在于:python的类方法的第一个参数都必须带self参数。


Python的类的方法和普通的函数有一个很明显的区别,在类的方法必须有个额外的第一个参数
(self),但在调用这个方法的时候不必为这个参数赋值(显胜于隐的引发)。Python的类的方法的这个特别的参数指代的是对象本身,而按照Python的惯例,它用self来表示。(当然我们也可以用其他任何名称来代替,只是规范和标准在那建议我们一致使用self)

为何Python给self赋值而你不必给self赋值?

例子说明:创建了一个类MyClass,实例化MyClass得到了MyObject这个对象,然后调用这个对象的方法MyObject.method(arg1,arg2)
,这个过程中,Python会自动转为Myclass.mehod(MyObject,arg1,arg2)

这就是Python的self的原理了。即使你的类的方法不需要任何参数,但还是得给这个方法定义一个self参数,虽然我们在实例化调用的时候不用理会这个参数不用给它赋值。

class Python:
 def selfDemo(self):
  print 'Python,why self?'
p = Python()
p.selfDemo()


把p.selfDemo()带个参数如:p.selfDemo(p),得到同样的输出结果



首先明确的是self只有在类的方法中才会有,独立的函数或方法是不必带有self的。self在定义类的方法时是必须有的,虽然在调用时不必传入相应的参数。
self名称不是必须的,在python中self不是关键词,你可以定义成a或b或其它名字都可以,但是约定成俗,不要搞另类,大家会不明白的。下例中将self改为myname一样没有错误:

class Person:
          def __init__(myname,name):
                   myname.name=name
          def sayhello(myname):
                   print 'My name is:',myname.name
p=Person('Bill')
print p #<__main__.Person instance at 0x7f1573d2d908>

self指的是类实例对象本身(注意:不是类本身)。

class Person:
         def __init__(self,name):
                  self.name=name
         def sayhello(self):
                  print 'My name is:',self.name
p=Person('Bill')
print p #<__main__.Person instance at 0x7f1573d2d908>

在上述例子中,self指向Person的实例p。 为什么不是指向类本身呢,如下例子:

class Person:
         def __init__(self,name):
                  self.name=name
         def sayhello(self):
                  print 'My name is:',self.name
p=Person('Bill')
p1 = Person('Apple')
print p

如果self指向类本身,那么当有多个实例对象时,self指向哪一个呢?


有self必是方法(method),而不是函数。其余的楼上说的都很对

http://www.pythoneye.com.cn/pythonshipin/%E8%BF%AA%E8%89%BE%E5%A7%86python%E5%9F%B9%E8%AE%AD_python%E5%9F%B9%E8%AE%AD_%E5%AE%9E%E4%BE%8B%E5%AF%B9%E8%B1%A1.flv

self代表类的实例,而非类。

参考资料

Python中self用法详解 Python self参数 & 函数详解 Python self 详解 彻底搞清楚Python中self的含义 Python为什么要self 深入理解python之self