python-day08-oop类的概念及封装

一、面向对象(oop:object oriented programming)的概念

编程语言分为2种,面向对象和面向过程。
面向过程:-------->侧重怎么做?
1.把完成某一个需求的 所有步骤 从头到尾 逐步实现
2.根据开发要求,将某些功能独立的代码封装成一个又一个函数
3.最后完成的代码,就是顺序的调用不同的函数
特点:
1.注重步骤和过程,不注重职责分工
2.如果需求复杂,代码变得非常复杂
3.开发复杂的项目的时候,没有固定的套路,开发难度很大

面向对象:--------->侧重谁来做?
相比较函数,面向对象是更大的封装,根据职责在一个对象中封装多个方法
1.在完成某一个需求前,首先确定职责–要做的事(方法)
2.根据职责确定不同的对象,在对象内部封装不同的方法(多个)
3.最后完成代码,就是顺序的让不同的对象调用不同的方法
特点:
1.注重对象和职责,不同的对象承担不同的职责
2.更加适合对复杂的需求变化,是专门应对复杂项目的开发,提供固定的套路
3.需要在面向过程的基础上,再学习一些面向对象的语法
面向对象有两个核心的概念:
类:是一类具有相同特征或行为的事物的一个统称
对象:由类创建出来的一个具体的存在
类和对象的关系:先有类再有对象
类是模板 对象是根据这个模板创建出来的
类只需要有一个 对象可以有多个


类:属性(这一类事务的共同信息) 和 方法(你能完成的动作)
1.类名:这类事物的名字(大驼峰命名法)
大驼峰命名法:
1.每个单词的首字母大写
2.单词与单词之间没有下划线
2.属性:这个类创建出来的对象有什么特征
3.方法:这个类创建出来的对象有什么行为


类名的确定
名词提炼法分析整个业务流程,出现的名词,通常就是找到的类。
属性和方法的确定
对 对象的特征描述,通常可以定义成属性
对象具有的行为(动词),通常可以定义为方法
提示:需求中没有涉及的属性或方法在设计类时,不需要考虑

二、定义一个初级的类

class Cat:  定义一个类
    def eat(self):
        print('%s 爱吃鱼' %(self.name))
    def drink(self):
        print('猫要喝水')
hellokitty=Cat() #类的实例化(产生一个对象)
hellokitty.name = 'apple' #给对象起个名字
print(hellokitty)
hellokitty.eat()

在这里插入图片描述self:
哪一个对象调用的方法,self就是哪一个对象的引用(指向对象的内存地址空间)
在调用方法的时候,程序员就不需要传递self参数(定义的时候,第一个参数必须是self)

三、初始化方法

初始化方法:类名()就可以创建一个对象,类名创建的时候python解释器会执行哪些操作:
1.为对象在内存中分配空间—>创建对象
2.自动调用初始化方法为对象的属性设置初始值
这个初始化方法是内置方法,是专门用来定义一个类具有哪些属性。

class Cat:
    def __init__(self,name):
        self.name=name
    def eat(self):
        print('%s 爱吃鱼' %(self.name))
    def drink(self):
        print('%s要喝水' %(self.name))
tom = Cat('ttom') #实例化一个对象,起名为ttom
tom.eat()
tom.drink()

在这里插入图片描述

四、_str_内置方法

_str_:在python中,使用print输出对象变量的时候
默认情况下这个变量引用的对象是由哪一个类创建的对象及其在内存中的地址
如果在开发中 希望使用print输出变量的时候,能够打印自定义内容
就可以利用__str__这个内置的方法

class Cat:
    def __init__(self,name):
        self.name = name
    def __str__(self):
        # 返回必须是一个字符串
        return '我是 %s' %(self.name)
tom = Cat('ttom')
print(tom)
addr = id(tom)
print(addr)
# 十六进制
print('%x' %(addr))
# 十进制
print('%d' %(addr))

在这里插入图片描述

五、_del_内置方法

1.自动删除

class Cat:
    def __init__(self,name):
        self.name = name
        print('%s 来了' %(self.name))
    def __del__(self):
        print('%s 走了' %(self.name))
tom  = Cat('tttom')
print(tom.name)
# del tom
print('*' * 50)
print(tom.name)

在这里插入图片描述2.手动删除,提前删除,不让系统删除。

class Cat:
    def __init__(self,name):
        self.name = name
        print('%s 来了' %(self.name))
    def __del__(self):
        print('%s 走了' %(self.name))
tom  = Cat('tttom')
print(tom.name)
del tom
print('*' * 50)
print(tom.name)

提前删除了,再次打印,会报错
在这里插入图片描述

六、封装

1.封装是面向对象编程的一大特点
2.面向对象编程的第一步,将属性和方法封装到一个抽象(因为类不能直接使用)的类中
3.外界使用类创建对象,然后让对象调用方法
4.对象方法的细节都被封装在类的内部

需求:
1.小明体重75.0公斤
2.小明每次跑步都会减肥0.5公斤
3.小明每次吃东西体重都会增加1公斤

class Person:
    def __init__(self,name,weight):
        self.name=name
        self.weight=weight
    def __str__(self):
        return '我的名字叫%s,我的体重%skg' %(self.name,self.weight)
    def run(self):
        self.weight-=0.5
        print('%s去跑完步后,体重为%s' %(self.name,self.weight))
    def eat(self):
        self.weight+=1
        print('%s吃完东西后,体重为%s' %(self.name,self.weight))
a=Person('小明',55)
print(a)
a.eat()
a.run()

在这里插入图片描述

牛刀小试:
练习1:
编写一个类,实现栈的一些功能:先进后出, 入栈 ,出栈(pop), 取栈顶元素,判断栈是否为空 显示栈元素。

class Stack:
    def __init__(self):
        self.stack=[]
    def push(self,value): #入栈
        self.stack.append(value)
        return True
    def pop(self): #出栈,先判断是否为空
        if self.stack: #若不为空
            item=self.stack.pop()
            return item
        else:#若为空
            return False
    def top(self):
        if self.stack:
            return self.stack[-1]
        else:
            return False
    def length(self):
        return len(self.stack)
    def view(self):
        return self.stack
s=Stack()
s.push('2') #入栈
s.push('5')#入栈
s.push('888')#入栈
print(s.length())#长度
print(s.view())#查看
print(s.pop())#出栈

在这里插入图片描述
练习2:
实现一个关于家居及房子大小方面的类
需求:
“”"

1.房子有户型,总面积和家具名称列表
新房子是没有家具的
2.家具有名字和占地面积,其中
eg:占地 6平方米
3.将以上三件家具添加到房子中
4.打印房子的时候,要求输出:户型 总面积 剩余面积 家具名称列表
“”"

class Furniture:
    def __init__(self,name,area):
        self.name=name
        self.area=area
    def __str__(self):
        return '%s占地%s平方米' %(self.name,self.area)
class House:
    def __init__(self,style,area):
        self.style=style
        self.area=area
        self.free_area=area #剩余面积
        self.Fur_item=[]
    def __str__(self):
        return '该户型是%s,面积共%s平方,家具有:%s,剩余%.2f平方' \
               %(self.style,self.area,self.Fur_item,self.free_area)
    def add_Fur(self,item):
        if item.area>self.free_area:
            print('%s的面积太大,无法添加' %(item.name))
            return
        self.Fur_item.append(item.name)
        self.free_area-=item.area
#创建家具
bed=Furniture('床',3.6)
table=Furniture('桌子',2)
bench=Furniture('板凳',0.8)
#打印家具的属性
print(bed)
print(table)
print(bench)
###########
#创建房子
hh=House('三室一厅',127)
print(hh)# 打印房子属性
#将家具添加到房子里
hh.add_Fur(bed)  #一个类创建出来的对象可以调用另一个对象
hh.add_Fur(table)
hh.add_Fur(bench)
#打印房子属性
print(hh)

在这里插入图片描述
练习3:
“”"
1.士兵瑞恩有一把AK47
2.士兵可以开火(士兵开火扣动的是扳机)
3.枪 能够 发射子弹(把子弹发射出去)
4.枪 能够 装填子弹 --增加子弹的数量
“”"

class Gun:
    def __init__(self,name):
        self.name=name
        self.bul_count=0
    def add_bullet(self,count):
        self.bul_count+=count
    def shoot(self):
        if self.bul_count<=0:
            print('%s没有子弹了' %(self.name))
        self.bul_count-=1
        print('%s有%s发子弹' %(self.name,self.bul_count))
class Soldier:
    def __init__(self,name):
        self.name=name
        self.gun=None
    def kaihuo(self):
        if self.gun==None:
            print('%s没有枪,不能开火' %(self.name))
        self.gun.add_bullet(50) #self.gun=ak47,想调用枪的加子弹的方法,必须是有子弹的类(Gun)产生的对象
        self.gun.shoot()
ak47=Gun('Ak47')#产生一把枪
ryan=Soldier('Ryan')#产生一个士兵
ryan.gun=ak47 #给士兵一把枪,
ryan.kaihuo() #原本50发,射了一发,还有49

在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值