python基础学习之类

    • 面向对象和面向过程

      面向过程:以吃饭为例,即为 煮饭、洗菜、洗碗、切菜、炒菜、出锅、吃饭
      面向对象:目标对象做完,直接吃
      疑问点:1、面向对象就是把过程用函数封装起来,随时调用?;2、面向过程就是每次都把逻辑程序再走一遍?

      【初次接触,仅了解,上述疑问有待考证】

    • 如果定义一个类

      class 类名(首字母大写):

          代码块(类属性定义)

      举个栗子:

      class MyFruit :
              name = '疏楼龙宿'
          age = 31
      这就是一个类

    • 调用类

      第一种方法是:类名.属性,即MyFruit.name,需要print;

      第二种方法是:

      实例化

      f = MyFruit()

      f.name

      f.age      同样需要print

    • 属性概念和私有属性

      类中的定义变量即为属性,该例子中的name、age即为属性

      私有属性是在变量名前面有下划线的(分一个下划线和两个下划线)

      class Person:
              name = '疏楼龙宿'
          _age = 31
          __money = 10000

      区别:

      print(Person.name)  #普通属性
      print(Person._age)  #前面有一个下划线,可以直接调用,和普通属性区别不大
      print(Person._Person__money)    #私有属性加强版,前面两个下划线,需要单下划线加类名加私有属性来使用

    • 方法

      即封装在类中的函数

      举个栗子:

      class Student:
              name = 'xxxx'
          def study(self):
              print('%s真帅'%(self.name))

      该类中的函数即是称作方法,最后是print还是return没有区别

    • 方法的调用

      通过实例化来调用

      a = Student()
      a.study()

    • 关于方法中的self参数

      谁调用了该方法,这个self就是哪个值self.name即这个值就是name的值,如果全局变量没有,就去类中寻找默认值(局部变量)【与函数的相反】

      举个栗子:

      longshou = Student()
      longshou.name = '疏楼龙宿'
      longshou.study()

      self所在的study函数被longshou调用,那么'self'就是'longshou',可见上述方法中的‘self.name’即为 ‘longshou.name’,全局变量中又有定义longshou.name = '疏楼龙宿',所以,按照格式化的规则传入该值

    • 魔法方法__init__(双下划线)

      意思是初始化,其作用其实是赋值,即在类下面定义一个魔法方法,然后如果在实例化的同时,类的()被传入了值,就会自动运行__init__方法处理,然后运行其他方法得出结果

      举个栗子:

      class Student:
              name = 'xxxx'
          def __init__(self,name,age):
              self.name = name
              self.age = age
          def study(self):
              print('%s已经%d岁了,但仍然是人间至帅'%(self.name,self.age))
      #=============假装自己是封装线?=================

      s = Student('疏楼龙宿',31)
      s.study()

      解释该代码块:

      在实例化该类的同时,传入“疏楼龙宿”和31两个值,符合触发__init__方法的条件,__init__方法开始运行,处理这两个参数,分别赋值,然后运行下一步的study方法,并提供刚刚赋值的结果。可以视作__init__的作用就是定义class的属性

    • 析构
      li = [1,2,3,4,5]
      del li
      print(li)   #报错
      pop、clear remove等是删除元素,del是删除列表指向,即内存中列表本身,或者说是取消列表定义
      del其实就是调取的‘ __del__’魔法方法
      class MyFriend:
          pass
      longshou = MyFriend()
      print(longshou) #输出是个内存地址
      del longshou
      print(longshou) #报错

      class MyFriend:
          def __del__(self):
              print("人间至帅-疏楼龙宿")
      longshou = MyFriend()       #实例化
      print(111111)
      del longshou               #删除该实例化的时候,会触发__del__方法,输出“人间至帅-疏楼龙宿”
      print(22222)

      当某个类中有__del__方法的时候,在py文件执行结束后,会自动触发。
      del是将该内存解放掉

猜你喜欢

转载自www.cnblogs.com/shuloulongxiu-lili/p/12342778.html