[PY3]——面向对象编程(1)
类的对象
|
有三种对象 |
可以做什么操作 |
包括什么属性 |
|
类对象 |
属性引用、实例化 |
函数方法、内置的属性、类变量 |
|
实例对象 |
属性引用 |
函数方法、类变量、实例变量 |
|
方法对象 |
1. 类对象、实例对象、方法对象
类[class]是抽象的模型
实例[instance]是根据类创建出来的一个个具体的“对象”
1.1 如何定义类
class 类名(表示该类是从哪个类继承下来的):
xxx
class ClassName:
<statement-1>
.
.
.
<statement-N>
1.2 属性引用
class Myclass(object):
'''A simple example about class'''
i=123
def f(self):
return "hello world"
def __init__(self,name,score):
self.name=name
self.score=score # 引用类变量、方法,都是合理的属性引用,分别返回一个整数和一个函数对象
print(Myclass.i) print(Myclass.f) ->这就叫做创建了方法对象,但要注意这只是创建了对象但不是调用了这个方法
<function Student.f at 0x7f81f42c58c8> # 类还有内置的属性可以被引用
print(Myclass.__doc__)
A simple example about class
print(Myclass.__name__)
Myclass
print(Myclass.__dict__)
{'__doc__': 'A simple example about class', '__init__': <function Myclass.__init__ at 0x7f0bf8fd0950>, '__module__': '__main__', '__weakref__': <attribute '__weakref__' of 'Myclass' objects>, 'i': 123, '__dict__': <attribute '__dict__' of 'Myclass' objects>, 'f': <function Myclass.f at 0x7f0bf8fd08c8>}
print(Myclass.__module__)
__main__
print(Myclass.__bases__)
(<class 'object'>,)
内置类 描述 __dict__ 类的属性 __doc__ 类的文档字符串 __name__ 类名 __module__ 类定义所在的模块 __bases__ 类的所有父类构成元素
1.3 实例化操作
# 实例化操作如下所示,赋值给一个变量,就能够创建一个实例对象
x=Myclass()
y=Myclass()
print(x.i) print(x.f())
hello world
print(x.__doc__)
A simple example about class
# 创建的实例对象可以自由地绑定属性
x.iii="a9a"
print(x.iii)
a9a
# 创建的每个实例对象的内存地址都不一样
print(x)
<__main__.Myclass object at 0x7fbe7fa53160>
print(y)
<__main__.Myclass object at 0x7fbe7f7a8630>
1.4 __init__
# 上述的实例化操作创建了一个空的object
# 但在很多情况下,我们创建实例对象时,可能都需要有特定的初始状态。这个由__init__方法实现。
# 当一个类定义了 __init__() 方法, 类在实例化时会自动调用 __init__() 方法, 用于创建新的类实例
class Myclass(object):
'''A simple example about class'''
i=123
def f(self):
return "hello world" def __init__(self,name,score):
self.name=name
self.score=score # 关于__init__,要注意的是:
(1) __init__方法的第一个参数永远是self,表示创建的实例本身
(2) 有了__init__方法,在创建实例时就不能传入空的参数了,必须传入匹配的参数
x=Myclass()
TypeError: __init__() missing 2 required positional arguments: 'name' and 'score' x=Myclass("J",11)
print(x.name,x.score)
J 11
2. 属性之“变量属性”、作用域问题、访问限制问题
2.1 类变量、实例变量、作用域
class test:
x=7 #类的直接下级作用域的变量,叫做类变量 def __init__(self,name):
self.name=name #实例中的变量,叫实例变量 instance1=test("name1")
instance2=test('name2') # 类变量:既是类对象可见的属性、也是实例对象可见的属性
print(test.x) print(instance1.x) # 下面的例子中,instance1.x+=100本质是实例对象instance1新建了一个属性,覆盖了instance1.x这个变量
# 我们要知道,类变量可以是类对象的属性也可以是实例对象的属性,但实例对象的属性变化影响不了类对象的属性,也不会影响其他的实例对象
# 反之,类对象属性的变化倒是能影响实例对象的属性
test.x=100
print(instance1.x) print(test.x) instance1.x+=100
print(instance1.x) print(test.x) print(instance2.x)
2.2 访问限制
# 如果要让内部属性不被外部访问,可以把属性的名称前加上两个下划线__,在Python中,实例的变量名如果以__开头,就变成了一个私有变量(private),只有内部可以访问,外部不能访问
# 这样就确保了外部代码不能随意修改对象内部的状态,这样通过访问限制的保护,代码更加健壮 class Student(object):
def __init__(self,name,score):
self.__name=name
self.__score=score stu=Student('J',100)
print(stu.__score)
AttributeError: 'Student' object has no attribute '__score' # 如果要允许外部访问者两个变量,可以增加get方法(get_name()和get_score())
# 如果又要允许外部修改这两个变量,可以增加set_score,虽然显得大费周折,但我们可以顺带对参数做个检查 class Student(object):
def __init__(self,name,score):
self.__name=name
self.__score=score def get_name(self):
return '{}'.format(self.__name) def get_score(self):
return '{}'.format(self.__score) def print_stu(self):
print('%s:%s' % (self.__name,self.__score)) def set_score(self,score):
if 0<=score<=100:
self.__score=score
else:
raise ValueError('bad score') stu=Student('J',100)
print(stu.get_name())
J
print(stu.get_score()) stu.print_stu()
J:100 stu.set_score(99);print(stu.get_score()) stu.set_score(101)
ValueError: bad score
3. 父类、子类(继承、多态)
# 基类/父类/超类(base class/super class) <—— 子类(subclass) class Animal(object):
def run(self):
print("Animal is running...") def run2(self):
print("") class Dog(Animal):
def run(self):
print("Dog is running...") class Cat(Animal):
def run(self):
print("Cat is running...") animal=Animal()
dog=Dog()
cat=Cat() # 子类父类存在同名方法时,子类方法覆盖父类方法
dog.run()
Dog is running...
dog.run2() cat.run()
Cat is running... # 可以通过isinstance(obj, class_or_tuple, /),可以判断一个instance object是否属于某个类
print(isinstance(dog,Dog))
True
print(isinstance(dog,Animal))
True
print(isinstance(animal,Dog))
False # issubclass(cls, class_or_tuple, /)class Base:
Public_class_var='public class var' #类变量(public)
__Private_class_var='private class var' #类变量(private) def __init__(self):
self.public_instance_var='public instance var' #实例变量(public)
self.__private_instance_var='private instance var' #实例变量(private) def public_instance_method(self):
return 'public instance method' def __private_instance_method(self):
return 'private instance method' @classmethod
def public_class_method(cls):
return 'public class method' @classmethod
def __private_class_method(cls):
return 'private class method' @staticmethod
def public_static_method():
return 'public static method' @staticmethod
def __private_static_method():
return 'private static method' class Sub(Base):
pass sub=Sub()
print(sub.__dict__)
{'_Base__private_instance_var': 'private instance var', 'public_instance_var': 'public instance var'}
# 子类可以继承类变量(public)、实例变量(public)
class Sub(Base):
def print_public_var(self):
print(self.Public_class_var) def print_public_instance_var(self):
print(self.public_instance_var) sub=Sub()
sub.print_public_var()
public class var sub.print_public_instance_var()
public instance var # 事实上凡是公有的都能继承,凡是私有的都不能继承
class Sub(Base):
def print_public_class_method(self):
print(self.public_class_method()) def print_public_static_method(self):
print(self.public_static_method()) def print_public_instance_method(self):
print(self.public_instance_method()) sub=Sub()
sub.print_public_class_method()
public class method
sub.print_public_static_method()
public static method
sub.print_public_instance_method()
public instance method
4. classmethod、staticmethod
class A(object):
def foo(self,x):
print("executing foo({},{})".format(self,x)) @classmethod
def class_foo(cls,x):
print("executing class_foo({},{})".format(cls,x)) @staticmethod
def static_foo(x):
print("executing static_foo({})".format(x)) a=A() a.foo(1)
executing foo(<__main__.A object at 0x7fe8619c7160>,1) a.class_foo(1)
executing class_foo(<class '__main__.A'>,1) a.static_foo(1)
executing static_foo(1) a.static_foo('hi')
executing static_foo(hi) A.class_foo(1)
executing class_foo(<class '__main__.A'>,1) A.static_foo(1)
executing static_foo(1) A.foo(1)TypeError: foo() missing 1 required positional argument: 'x' print(a.foo)
<bound method A.foo of <__main__.A object at 0x7f57d0ba41d0>> print(a.class_foo)
<bound method A.class_foo of <class '__main__.A'>> print(a.static_foo)
<function A.static_foo at 0x7f71b0c89b70>
参考文章
[PY3]——面向对象编程(1)的更多相关文章
- python_面向对象编程
一.编程范式 程序员通过特定的语法+数据结构+算法告诉计算机如果执行任务,实现这个过程有不同的编程方式,对这些不同的编程方式进行归纳总结得出来的编程方式类别,即为编程范式 编程范式:面向过程编程.面向 ...
- Python入门之面向对象编程(一)面向对象概念及优点
概念 谈到面向对象,很多程序员会抛出三个词:封装.继承和多态:或者说抽象.一切都是对象之类的话,然而这会让初学者更加疑惑.下面我想通过一个小例子来说明一下 面向对象一般是和面向过程做对比的,下面是一个 ...
- Python基础-week06 面向对象编程基础
一.面向对象编程 1.面向过程 与 面向对象编程 面向过程的程序设计: 核心是 过程二字,过程指的是解决问题的步骤,即先干什么再干什么......面向过程的设计就好比精心设计好一条流水线,是一种机械式 ...
- python面向对象编程设计与开发
一.什么是面向对象的程序设计 1.何为数据结构? 数据结构是指相互之间存在一种或多种特定关系的数据元素的集合,如列表.字典. 2.何为编程? 编程是指程序员用特定的语法+数据结构+算法,组成的代码,告 ...
- angular2系列教程(六)两种pipe:函数式编程与面向对象编程
今天,我们要讲的是angualr2的pipe这个知识点. 例子
- 带你一分钟理解闭包--js面向对象编程
上一篇<简单粗暴地理解js原型链--js面向对象编程>没想到能攒到这么多赞,实属意外.分享是个好事情,尤其是分享自己的学习感悟.所以网上关于原型链.闭包.作用域等文章多如牛毛,很多文章写得 ...
- PHP 面向对象编程和设计模式 (1/5) - 抽象类、对象接口、instanceof 和契约式编程
PHP高级程序设计 学习笔记 2014.06.09 什么是面向对象编程 面向对象编程(Object Oriented Programming,OOP)是一种计算机编程架构.OOP 的一条基本原则是计算 ...
- Delphi_09_Delphi_Object_Pascal_面向对象编程
今天这里讨论一下Delphi中的面向对象编程,这里不做过多过细的讨论,主要做提纲挈领的描述,帮助自己抓做重点. 本随笔分为两部分: 一.面向对象编程 二.面向对象编程详细描述 ------------ ...
- python基础-面向对象编程
一.三大编程范式 编程范式即编程的方法论,标识一种编程风格 三大编程范式: 1.面向过程编程 2.函数式编程 3.面向对象编程 二.编程进化论 1.编程最开始就是无组织无结构,从简单控制流中按步写指令 ...
随机推荐
- 如何统计TFS代码库中的团队项目所占用的磁盘空间
在一个开发团队较多的研发中心,当开发人员的代码数据积累到一定程度,TFS系统的磁盘空间的使用率会逐渐成为系统管理员关注的问题.你可能会关注代码库中每个团队项目,甚至每个目录占用的的磁盘空间.不幸的,即 ...
- gdb用法
mickole@test:~/ctest/05gdb$ gdb simple //开始gdb调试 GNU gdb (Ubuntu/Linaro 7.4-2012.04-0ubuntu2.1) 7.4- ...
- C#模拟请求,模拟登录,Cookie设置、文件上传等问题汇总
由于业务需求,最近需要模拟完成登陆某个网站,并上传所需要的文件.在开发途中,遇到了很多问题,现在,就我遇到的一些问题及解决办法说明如下,希望对遇到同样问题的人有所帮助.因为技术有限,可能有些内容并不完 ...
- django drf 动态权限配置和动态seriaizer_class配置
可以通过重写get_permissions方法和get_serializers_class方法来实现动态的配置权限和序列化 VIewDemo class RegUserSet(mixins.Creat ...
- 为什么不能用Abort退出线程
在使用线程时,如果线程还未结束直接退出线程很有可能会导致数据丢失. class threadAbort { static void Main(string[] args) { WriteMessage ...
- Json/XML序列化和反序列化
1.json序列化和反序列化 序列化是将对象状态转换为可保持或传输的格式的过程; 反序列化,它将流转换为对象; 1)Json.Net 推荐使用Json.Net类库,需要引入的命名空间; 序列化:Jso ...
- UWP开发---嵌套DataTemplate&模板选择器
对于Json结构体items不完全一致的情况下,在UWP平台是如何处理数据,并通过不同的模板选择,进行显示呢? 一,嵌套Json分析 1,结构 通过抓取index的API(点击请求API)获取到的js ...
- javar入门——基本数据类型
Java中的数据类型分为两类: 基本数据类型(或者称为原生数据类型) 引用数据类型 基本数据类型 8种:6种基本数据类型,1种字符型,1种布尔型 byte,short,int,long,float,d ...
- const的详解
1.const的成员变量 常成员变量的值不能被更新,将在构造函数时候进行初始化 2.const的成员函数 常成员函数只能调用常成员函数,常成员函数不能修改任何成员变量的数值 3.const的成员对象 ...
- Python 断言 assert 的用法
assert 后边接的表达式的返回值必须是布尔值 assert expression, "对错误的描述信息" 如果expression表达式返回的是True, 程序正常执行, 如果 ...