python 类中的方法

python 类中的方法

上一篇中讲到 创建了类,并且重点讲述了构造函数以及类实例,特别是对那个self,描述了不少。在讲述构造函数的时候特别提到,init()是一个函数,只不过在类中有一点特殊的作用罢了,每个类,首先要运行它,它规定了类的基本结构。

数据流转过程

除了在类中可以写这种函数之外,在类中还可以写别的函数,延续上一个例子:

#!/usr/bin/env python
#coding:utf-8

class Person:
    def __init__(self, name, lang="golang", website="www.google.com"):
        self.name = name
        self.lang = lang
        self.website = website
        self.email = "hiekay@gmail.com"

    def author(self):
        return self.name

hiekay = Person("hiekay")
info = Person("h",lang="python",website="hiekay.github.io")

print "Author name from hiekay:",hiekay.author()
print "Author name from info:",info.author()

#运行结果

Author name from hiekay: hiekay
Author name from info: h

这段代码比多了一个函数author(self),这个我们先不管,稍后会详细分解。首先看看数据是如何在这个代码中流转的。

定义类Person,然后创建实例hiekay=Person(“hiekay”)。hiekay这个实例和Person类中的self对应,它们都是引用了实例对象(很多时候简化说成是实例对象)。”hiekay”是一个具体的数据,通过构造函数中的name参数,传给实例的属性self.name,在类Person中的另外一个方法author的参数列表中第一个就是self,表示要承接self对象,return self.name,就是在类内部通过self对象,把它的属性self.name的数据传导如author。

当运行hiekay.author()的时候,就是告诉上面的代码,调用hiekay实例对象,并得到author()方法的结果,hiekay这个实例就自动被告诉了author()(注意,self参数在这里不用写,这个告诉过程是python自动完成的,不用我们操心了),author方法就返回hiekay实例的属性,因为前面已经完成了hiekay与self的对应过程,所以这时候author里面的self就是hiekay,自然self.name=hiekay.name。

再做一个实验,那就是在author中,return hiekay.name,看看什么效果。因为既然hiekay和self是同一个实例对象,直接写成hiekay.name是不是也可以呢?

#!/usr/bin/env python
#coding:utf-8

class Person:
    def __init__(self, name, lang="golang", website="www.google.com"):
        self.name = name
        self.lang = lang
        self.website = website
        self.email = "hiekay@gmail.com"

    def author(self):
        #return self.name
        return hiekay.name       #返回

hiekay = Person("hiekay")
info = Person("h",lang="python",website="hiekay.github.io")

print "Author name from hiekay:",hiekay.author()
print "Author name from info:",info.author()

#输出结果
Author name from hiekay: hiekay   #hiekay实例输出结果
Author name from info: hiekay    #info实例输出结果

从结果中可以看出,没有报错。但是,info这个实例输出的结果和hiekay实例输出的结果一样。原来,当调用了info实例之后,运行到author(),返回的是hiekay.name。所以,这里一定要用self实例。在调用不同的实例时,self会自动的进行匹配,当然,匹配过程是python完成,仍然不用我们操心。

为什么要用到方法

在类里面,可以用def语句来编写函数,但是,通常这个函数的样子是这样的:

class ClassName:
    def __init__(self,*args):
        ...
    def method(self,*args):     #是一个在类里面的函数
        ...

在类ClassName里面,除了前面那个具有初始化功能的构造函数之外,还有一个函数method,这个函数和以前学习过的函数一样,函数里面要写什么,也没有特别的规定。但是,这个函数的第一个参数必须是self,或者说,可以没有别的参数,但是self是必须写上并且是第一个。这个self参数的作用前面已经说过了。

这样看来,类里面的这个函数还有点跟以前函数不同的地方。

类里面的这个函数,我们就称之为方法

之所以用方法,也是用类的原因,也是用函数的原因,都是为了减少代码的冗余,提高代码的重用性,这也是OOP的原因。

方法怎样被重用呢?看本最开始的那段代码,里面有一个author方法,不管是hiekay还是info实例,都用这个方法返回实例导入的名字。这就是体现了重用。

编写和操作方法

编写方法的过程和编写一个函数的过程一样,需要注意的就是要在参数列表中第一个写上self,即使没有其它的参数。

#!/usr/bin/env python
#coding:utf-8

class Person:
    def __init__(self, name, lang="golang", website="www.google.com"):
        self.name = name
        self.lang = lang
        self.website = website
        self.email = "hiekay@gmail.com"

    def author(self, address):
        #return self.name
        return hiekay.name+" in "+address

hiekay = Person("hiekay")
info = Person("h",lang="python",website="hiekay.github.io")

print "Author name from hiekay:",hiekay.author("China")
print "Author name from info:",info.author("SH")

#运行结果

Author name from hiekay: hiekay in China
Author name from info: hiekay in SH

这段代码中,对author方法增加了一个参数address,当调用这个方法的时候:hiekay.author(“China”),要对这个参数赋值,在类中,这个方法显示是有两个参数(self,address),但是在调用的时候,第一个参数是自动将实例hiekay与之对应起来,不需要显化赋值,可以理解成是隐含完成的(其实,也可以将hiekay看做隐藏的主体,偷偷地跟self勾搭上了)。

通过上面的讲述,看官可以试试类了。提醒,一定要对类的数据流通过程清晰。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/101235.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 计算机网络p2p协议在第几页_p2p传输协议

    计算机网络p2p协议在第几页_p2p传输协议在上篇文章中说过,要写写P2P协议的,嗯,来写写,虽然写的不是太好.P2P是什么?还是要回到这个场景:如果想要下载一个电影,一般都是通过什么方式呢?我希望这次你的答案,除了HTTP方式,还有FTP方式(要不上篇文章岂不是白写了?)但是你发现了嘛,不管是HTTP的方式,还是FTP的方式,都有一个比较大的缺点,就是难以解决单一服务器的带宽压力,因为它们使用的都是传统的…

    2022年10月21日
    1
  • 运行疑难解答时出错0x8000FFFF_vs2010由于缺少调试目标

    运行疑难解答时出错0x8000FFFF_vs2010由于缺少调试目标发生错误,需要终止调试。有关更多详细信息,请参阅Microsoft帮助和支持网站。HRESULT=0x8000ffff。ErrorCode=0x0。工程目录太深会导致上述错误发生,把整个工程文件往外移即可

    2022年9月24日
    2
  • 构建算法模型_模型与算法有什么不同

    构建算法模型_模型与算法有什么不同文章目录1.情感词典内容2.情感倾向点互信息算法(SO-PMI)算法点互信息算法PMI情感倾向点互信息算法SO-PMI3.构建情感词典1.导入项目2.构建情感种子词3.使用TF-IDF方便构建情感种子词4.构建专业词典的效果与使用方法5.其他说明1.情感词典内容情感词典构建方法归为三类,分别是:词关系扩展法、迭代路径法和释义扩展法情感极性:正向、负向;表示正面情感(开心愉快)或负面情感(伤心愤怒)情感极值:情感倾向(微笑、开怀大笑、手舞足蹈虽然都可以表示开心,但有不一样的

    2022年8月23日
    6
  • 37岁男子投简历被HR嘲讽,爆出聊天记录后,网友:HR说的没毛病「建议收藏」

    37岁男子投简历被HR嘲讽,爆出聊天记录后,网友:HR说的没毛病

    2022年2月13日
    47
  • android swiperefreshlayout 自定义,SwipeRefreshLayout 的使用详解

    android swiperefreshlayout 自定义,SwipeRefreshLayout 的使用详解SwipeRefreshLayout作为谷歌官方推荐的下拉刷新控件,同时简单而又不失优雅的风格,让许多app都使用了这一控件,今天记录下SwipeRefreshLayout在项目中的实际运用。首先,我们在布局文件中使用:android:id=”@+id/swipeRefreshLayout”android:layout_width=”match_parent”android:layout_heig…

    2022年6月25日
    26
  • ucos创建任务流程图_createthread函数的参数

    ucos创建任务流程图_createthread函数的参数uC/OS-III任务创建函数OSTaskCreate()1.OSTaskCreate()函数原型voidTaskCreate(OS_TCB*p_tcb,//任务控制OS_TCB的地址CPU_CHAR*p_name,//任务的名字OS_TASK_PTRp_task,//任务代码的起始地址void*p_arg,//任务第一次运行时接收到

    2025年9月17日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号