OOP跟我来
世界一切 归于尘土
all is object
两大杀手锏:对象 类
三大武器:封装;继承;多态
#!/usrself=Nonepython
# -*- coding: utf-8 -*-
# @File : people.py
# @Author: wmy
# @Date : 2018/1/21
class Person:
aera = '地球'
def __init__(self,name,age):
self.name = name
self.age = age
def display_info(self):
print(" -->%s已经%d岁,"%(self.name,self.age))
print("现住在%s..."%self.aera)
p1 = Person('zhangsan',20)
p1.display_info()
以上给出了一个简单的类,其中p1为实例对象。
添加属性:
p1.sex = 'male'
打印结果如下:
-->zhangsan已经20岁,
现住在地球...
male
python很容易对类的属性进行操作。
现在构造第二个对象:
p2 = Person('张天',40)
p2.display_info()
输出结果如下:
-->张天已经40岁,
现住在地球...
公共类变量:节省存储空间
继承如下
class Teacher(Person):
def __init__(self,name,age,school):
Person.__init__(self,name,age)
self.school = school
def display_info(self):
Person.display_info(self)
print('%s在%s学校任职'%(self.name,self.school))
通过类似公共接口的父类info函数,实现多态。这是Java不能如此简单实现的。
class Person:
aera = '地球'
def __init__(self,name,age):
self.name = name
self.age = age
def display_info(self):
print(" -->%s已经%d岁,"%(self.name,self.age))
print("现住在%s..."%self.aera) @staticmethod
def info(obj):
obj.display_info() class Teacher(Person):
def __init__(self,name,age,school):
Person.__init__(self,name,age)
self.school = school
def display_info(self):
Person.display_info(self)
print('%s在%s学校任职'%(self.name,self.school)) class Doctor(Person):
def __init__(self,name,age,medicine):
Person.__init__(self,name,age)
self.medicine = medicine
def display_info(self):
Person.display_info(self)
print('%s在%s医院任职'%(self.name,self.medicine)) t = Teacher('马玉',20,'第二中学')
d = Doctor('赵慎',34,'华西医院')
t.display_info()
d.display_info()
print('-------------------------')
p = Person('福清',40)
p.info(t)
p.info(d)
结果如下:
-->张丹已经20岁,
现住在地球...
张丹在第二中学学校任职
-->扑打已经34岁,
现住在地球...
扑打在华西医院医院任职
-------------------------
-->张丹已经20岁,
现住在地球...
张丹在第二中学学校任职
-->扑打已经34岁,
现住在地球...
扑打在华西医院医院任职
小编带领大家学习了一下Python,这种语言面向编程相对Java和C++来说。简单许多哟!
OOP跟我来的更多相关文章
- c#面向对象基础技能——学习笔记(二)基于OOP思想研究对象的【属性】
字段(成员变量): 字段只能从对象中访问实例字段,无法直接从类中访问(换言之,不创建实例就不能访问),可以理解为:字段一般用在内部数据交互使用,当需要为外部提供数据时,(要优先使用自动实现的属性而不是 ...
- 一个简单oop的changeTab
好多地方都会用到这样一个效果“点击tab切换内容页”,根据自己的想法实现了一下,写了个简单的插件.以前写代码都是标准的函数式编程,现在觉得面向对象编程看起来比较爽,并且更容易维护,于是就用oop的思想 ...
- Python OOP(面向对象编程)
一OOP的作用 在Python中,类是面向对象设计(OOP)的主要工具.通过使用类这种工具,OOP可以: 1.分解代码,最小化代码的冗余. 2.通过定制现有的代码,来编写新的程序,而不用在原处进行修改 ...
- OOP,WEB开发实用小技巧
偶然读到一篇博客,记录一下心得.这种设计对于新手来说一般是想不到的,它充分的发挥了OOP语言的特性,让代码专用而清爽.这是不是重构的思想呢? 我们在写业务层的时候,有很多方法是重复功能的,我们就可以使 ...
- 从OOP的角度看Golang
资料来源 https://github.com/luciotato/golang-notes/blob/master/OOP.md?hmsr=toutiao.io&utm_medium=tou ...
- 玩转JavaScript OOP[2]——类的实现
概述 当我们在谈论面向对象编程时,我们在谈论什么?我们首先谈论的是一些概念:对象.类.封装.继承.多态.对象和类是面向对象的基础,封装.继承和多态是面向对象编程的三大特性. JavaScript提供了 ...
- Atitit 面向对象编程(OOP)、面向组件编程(COP)、面向方面编程(AOP)和面向服务编程(SOP)的区别和联系
Atitit 面向对象编程(OOP).面向组件编程(COP).面向方面编程(AOP)和面向服务编程(SOP)的区别和联系 1. 面向组件编程(COP) 所以,组件比起对象来的进步就在于通用的规范的引入 ...
- iOS - 对OOA、OOD、OOP的理解
很多人在求职的时候,会遇到一个这样的问题:“对OOD/OOP有较深的理解”,这个时候有人就会问OOD.OOP是什么呢?那么今天咱们就一块来看一下OOA.OOD.OOP到底是什么! (一)OOA--面向 ...
- OOP感悟
行内讲的最多的就是出来一年内基本靠copy,一年后才基本懂得如何去写代码,而理解领悟oop,需要的时间却不定. 我工作中,我发现很多人拿着面向对相当的语言作者做着面向过程的事情,不需要知其所以然,只要 ...
随机推荐
- vue-cli卸载旧版,再重新安装后还显示的是旧的版本
按vue-cli的官方文档中卸载了旧版(2.8.2),然后重装了新版本,之后输入 vue --version还是显示2.8.2,最后发现关闭终端后重新打开终端,再看vue --version显示的是新 ...
- VUE 创建element项目
前提:电脑安装git node.js 一.右键Git Bash Here 二.$ vue init webpack element //新建一个element项目,element是文件夹名字 $ cd ...
- Element-ui框架checkbox复选框回显
先看下效果是不是你需要的..... 然后废话不多说,上代码,希望能够帮助到你... <template> <div class=''> <el-form label-wi ...
- 找到多个与名为“Home”的控制器匹配的类型
“/”应用程序中的服务器错误. 找到多个与名为“Home”的控制器匹配的类型.如果为此请求(“{controller}/{action}/{id}”)提供服务的路由没有指定命名空间以搜索与此请求相匹配 ...
- 查看当前Jquery版本
<script type="text/javascript"> $(document).ready(function(){ alert(jQuery.fn.jquery ...
- nginx日志相关运维操作记录
在分析服务器运行情况和业务数据时,nginx日志是非常可靠的数据来源,而掌握常用的nginx日志分析命令的应用技巧则有着事半功倍的作用,可以快速进行定位和统计. 1)Nginx日志的标准格式(可参考: ...
- 10、Typescript-类的基本用法
类就是构造函数的另一写法 以前构造函数的写法: 类的基本用法:
- html页面禁止用户右键粘贴复制保存的代码
HTML页面禁止选择.页面禁止复制.页面禁止右键 原创古城寨主2018-03-01 17:50:59评论(1)228人阅读 HTML页面内容禁止选择.复制.右键 刚在一个看一个站点的源代码的的时候 ...
- 4ci
- 总结Jquery中获取自定义属性使用.attr()和.data()以及.prop()的区别
一..attr()和.data()的区别: .attr()和.data()本质上属于DOM属性和Jquery对象属性的区别. 看一个例子: <!DOCTYPE html> <html ...