Python【面向对象编程】
#1、python中,类名首字母都大写
#2、在python3中,经典类和新式类没有任何区别
#3、在python2中,经典类和新式类的区别主要体现在多继承上,经典类是深度优先,新式类是广度优先
#4、在python3中,都是广度优先 #定义一个【经典类】
class Japanese:
pass #定义一个【新式类】
class Chinese(object):
pass print("=============定义一个类===========")
class Person(object):
#构造函数:可有可无,不是必须存在的
#在实例化一个类的对象时,自动执行构造函数,不需要我们手动显式的调用构造函数
def __init__(self,skin='white',nose='high',eye='blue'):
self.skin_color = skin
self.nose = nose
self.eye_color = eye
self.__language='english'
# 析构函数:在实例被销毁的时候自动执行,不需要我们手动调用析构函数
# 析构函数可有可无,不是必须存在的,一般可在该函数中,执行一些关闭数据连接的操作
def __del__(self):
# ..........
# ..........
# .......... 此处省略掉关闭数据库连接的代码行
pass
# 类变量:公共的变量,每个实例都可以用
country = 'usa'
#实例变量:比如前面构造函数中的【self.nose】,【self.skin_color】等,可以在所有实例方法中访问,也可以在类外部访问
#私有变量:比如前面构造函数中的【self.__language】,只能在类内部访问,类外部无法访问到,变量名是两个下划线开头命名的
#实例方法:self代表本类对象
#可以访问类变量和类方法
#可以访问静态方法
#可以访问属性方法
def run(self):
print(self.country)
self.eat_class_1()
self.sleep_static_1()
self.walk_property_1
self.run_1()
def run_1(self):
print("实例方法")
#属性方法:通过实例对象调用,不要通过类进行调用
@property
def walk_property(self):
print(self.country)
self.eat_class_1()
self.sleep_static_1()
self.run_1()
self.walk_property_1
@property
def walk_property_1(self):
print("属性方法")
#类方法:
# 1、不用实例化就可以直接调用
# 2、它可以通过cls使用类变量
# 3、它不能调用这个类里面的其他实例方法和实例变量
# 4、可以访问静态方法
# 5、cls代表对的就是Person
@classmethod
def eat_class(cls):
print(cls.country)
cls.sleep_static_1()
cls.walk_property_1
cls.eat_class_1()
@classmethod
def eat_class_1(cls):
print('类方法')
#静态方法
# 1、一个普通函数,只不过是写在类里面而已,它用不了类变量、类方法、实例变量、实例方法、属性方法、静态方法
@staticmethod
def sleep_static():
try:
self.run_1()
except Exception as e:
print(e)
try:
self.walk_property_1
except Exception as e:
print(e)
try:
self.sleep_static_1()
except Exception as e:
print(e)
try:
self.eat_class_1()
except Exception as e:
print(e)
@staticmethod
def sleep_static_1():
print('这个是静态方法,它和一个没写在类里面的函数一样')
#私有方法:只能在类内部访问,类外部无法访问到,方法名是两个下划线开头命名的
def __speak(self):
print ("这是个私有方法")
#实例方法:方法名是一个下划线开头命名的
def _shopping(self):
self._flower = "rose"
print("方法名一个下划线开头的实例方法")
def tool(self):
print(self.__language)
return self.__speak()
print("==========修改类变量===========")
#实例化两个美国人
p = Person()
p1 = Person() p.country='USA'
#Person.country = 'USA'
print("p.........:",p.country)
print('p1.......',p1.country)
print('Person.......',Person.country)
#结论:p.country='USA'和Person.country = 'USA'两种赋值方式有区别:
#1、通过Person.country = 'USA'这种方式给【country】类变量赋值,则:Person.country、p.country、p1.country 三个的值都是USA,
#说明影响的是类的所有实例以及类本身
#2、通过p.country='USA'这种方式给【country】类变量赋值,则:p.country的值是USA,而Person.country和p1.country的值是空,
#说明影响的是当前实例,并不会影响其他实例和类本身
print("========通过实例调用四种不同类型的方法=========")
print(p.walk_property) #通过实例调用属性方法:正确
print(p.eat_class()) #通过实例调用类方法:正确
print(p.sleep_static()) #通过实例调用静态方法:正确
print(p.run()) #通过实例调用实例方法:正确
print(p._shopping()) #通过实例调用一个下划线开头的实例方法:正确
print(p._flower) #通过实例调用一个下划线开头的成员变量:正确 print(p.tool()) #通过tool()方法间接调用私有方法和私有变量
print("========通过类调用四种不同类型的方法========")
print(Person.walk_property) #通过类调用属性方法:错误
print(Person.eat_class()) #通过类调用类方法:正确
print(Person.sleep_static()) #通过类调用静态方法:正确
#print(Person.run()) #通过类调用实例方法:错误
print("=======类的继承==========")
#支持多继承,比如class Japanese(Person,XXX,XX)
class Japanese(Person):
def play(self):
print("我是一个子类") #重写父类方法
def run(self):
# 调用父类方法
Person().run() #如果继承多个父类,super会根据继承的父类顺序,从左至右依次去找每一个父类,如果在某个父类中找到该方法,则停止寻找,
#直接实例化一个第一次找到的那个父类的对象,然后再调用父类的方法
super(Japanese, self).run()
print("重写父类方法") j1 = Japanese(nose='flat',skin='yellow',eye='black')
j2 = Japanese()
Japanese.country='Japan'
print('Japanese.......',Japanese.country)
print('j1........',j1.country)
print('j2........',j2.country)
# if __name__ == '__main__':
# 1、判断python文件是在别的地方导入的,还是直接运行的这个python文件
# 2、这句话一般是做调试的时候用的。
# 3、如果是直接运行这个python文件的时候,这句话一点用都没有
Python【面向对象编程】的更多相关文章
- python 面向对象编程学习
1. 问题:将所有代码放入一个py文件:无法维护 方案:如果将代码才分放到多个py文件,好处: 1. 同一个名字的变量互相不影响 2.易于维护 3.引用模块: import module 2.包:解决 ...
- python 面向对象编程(一)
一.如何定义一个类 在进行python面向对象编程之前,先来了解几个术语:类,类对象,实例对象,属性,函数和方法. 类是对现实世界中一些事物的封装,定义一个类可以采用下面的方式来定义: class c ...
- Python面向对象编程指南
Python面向对象编程指南(高清版)PDF 百度网盘 链接:https://pan.baidu.com/s/1SbD4gum4yGcUruH9icTPCQ 提取码:fzk5 复制这段内容后打开百度网 ...
- python面向对象编程进阶
python面向对象编程进阶 一.isinstance(obj,cls)和issubclass(sub,super) isinstance(obj,cls)检查是否obj是否是类 cls 的对象 1 ...
- Python面向对象编程(下)
本文主要通过几个实例介绍Python面向对象编程中的封装.继承.多态三大特性. 封装性 我们还是继续来看下上文中的例子,使用Student类创建一个对象,并修改对象的属性.代码如下: #-*- cod ...
- Python 面向对象编程——访问限制
<无访问限制的对象> 在Class内部,可以有属性和方法,而外部代码可以通过直接调用实例变量的方法来操作数据,这样,就隐藏了内部的复杂逻辑.但是,从前面Student类的定义来看(见:Py ...
- Python 面向对象编程 继承 和多态
Python 面向对象编程 继承 和多态 一:多继承性 对于java我们熟悉的是一个类只能继承一个父类:但是对于C++ 一个子类可以有多个父亲,同样对于 Python一个类也可以有多个父亲 格式: c ...
- Python 面向对象编程基础
Python 面向对象编程基础 虽然Pthon是解释性语言,但是Pthon可以进行面向对象开发,小到 脚本程序,大到3D游戏,Python都可以做到. 一类: 语法: class 类名: 类属性,方法 ...
- python面向对象编程学习
python面向对象编程 基本概念理解 面向对象编程--Object Oriented Programming,简称OOP,是一种程序设计思想.OOP把对象作为程序的基本单元,一个对象包含了数据和操作 ...
- Python面向对象编程——继承与派生
Python面向对象编程--继承与派生 一.初始继承 1.什么是继承 继承指的是类与类之间的关系,是一种什么"是"什么的关系,继承的功能之一就是用来解决代码重用问题. 继承是一种创 ...
随机推荐
- Eclipse各版本分析比较
Eclipse最初是由IBM公司开发的替代商业软件Visual Age for Java的下一代IDE开发环境,2001年11月贡献给开源社区,现在它由非营利软件供应商联盟Eclipse基金会. Ec ...
- vim 多个文件切换 :b 命令
MiniBufExplorer插件的使用 博客分类: vim vimMiniBufExplorer 快速浏览和操作Buffer -- 插件: MiniBufExplorer 下载地址 [http:// ...
- Scrum立会报告+燃尽图(十二月五日总第三十六次):Final阶段分配任务
此作业要求参见:https://edu.cnblogs.com/campus/nenu/2018fall/homework/2284 项目地址:https://git.coding.net/zhang ...
- java程序设计课程实验报告3
北京电子科技学院(BESTI) 实 验 报 告 课程:java程序设计 班级:1353 姓名:陈都 学号:20135328 成绩: 指导教师:娄 ...
- 剑指offer:二位数组中的查找
准备找实习期间,复习一下数据相关内容,刷刷题. 题目描述: 在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样 ...
- python learning GUI
Hello world1 from tkinter import * # 第一步是导入Tkinter包的所有内容 class Application(Frame): # 第二步是从Frame派生一个A ...
- python learning Process and Thread.py
# 多进程 # Windows下面没有fork ,请在linux下跑下面的代码 import os print('Process (%s) start...' % os.getpid()) pid = ...
- 重学 以太网的mac协议的CSMA/CD
之前上课一直模糊的CSMA/CD进行系统性整理. CSMA/CD (Carrier Sense Multiple Acess/Collision Detect)应用在OSI的 数据链路层 在以太网中, ...
- <构建之法>前三章读后感—软件工程
本教材不同于其他教材一贯的理知识直接灌溉,而是以对话形式向我们传授知识的,以使我们更好地理解知识点,更加清晰明确. 第一章 第一章的概述中,书本以多种方式,形象生动地向我们阐述了软件工程的内容,也让我 ...
- oracle greatest(),least( ) ,coalesce()
--场景1: select pt, greatest(wm), least(wm) from (select s.producttype pt, wm_concat(s.productid) wm f ...