首页投稿(暂停使用,暂停投稿)

Python第五天:面向对象

2017-10-28  本文已影响0人  我是周先生

:类的定义和创建对象:

类的定义:类变量

class Student:

        self.name=name
        self.age=age
    stu=Student('张三',23)
    stu2=Student('李四',33)
    print(stu.name)
    print(stu.age)
    print(stu2.name)

python中的方法:

1.实例方法:属于对象的方法,由对象自己维护的方法(对象的私有财产);
2.类方法:属于类的方法,有类来维护(对象的共有财产);
3.静态方法;函数占据了类的命名空间,调用时需要通过类名+方法的形式才能调用、静态方法和通过该类创建出来的对象没有任何关系;

    def __init__(self,name):
# 在py中一旦self执行和某个对象绑定,则该指针永远指向这个对象。
        self.name=name
实例方法就是在类的范围中创建一个函数:
    def hello(self):
        print('我的名字是'+self.name)
stu1=Student('林志玲')
stu1.hello()
stu2=Student('林志颖')
stu2.hello()
stu2.hello=stu1.hello
stu2.hello()
    country='China'
    def __init__(self,num):# 若要运行需要将num删掉
        self.num=num   # 这里属于实例变量
        self.country='usa'# 这里属于类变量
# 通过系统装饰器:@classmethod声明函数为类方法,类方法中的self指针指向类本身,
# 类方法只能访问类变量,不能访问实例变量
    @classmethod
    def say(cls):# 普通的方法传的是一个self,而@classmethod传入的是一个类变量
        print('我的国家是'+cls.country+cls.num) 
stu=Student('1')
stu.say()#通过实例调用
Student.say()
    @staticmethod
    def hello():
        print('我是来打酱油的')
stu=Student()
stu.hello()
print(type(Student.hello))
Student.hello()

class Date:
    # init 创建 对象
    def __init__(self,year,month,day):
        self.year=year
        self.month=month
        self.day=day
通过staticmethod装饰器修饰的方法是静态的方法,该方法没有指针所以不能和类,对象产生关系。如果某个方法不需要操作类,对象下的属性,就可以声明为静态方法
    @staticmethod
    def now():
        t=time.localtime();
        return Date(t.tm_year,t.tm_mon,t.tm_mday)
# date1 = Date(2017, 11, 10);
print(date1.year)
print(date1.month)
print(date1.day)

其他的方法:

    pass
a=A()
class B(A):
    pass
bol=isinstance(a,A)
print(bol)
    pass
a=A()
class B(A):
    pass
bol =issubclass(B,A)
print(bol)

通过__slots__来管理类的属性:

__slots__ = ('name','age')这是一个通过元组来管理类属性的内置方法:
使用它管理的属性,不允许类进行操作不属于slots操作的任何其他的类属性,一定程度上实现了类属性的安全性,而且元组是通过迭代的形式来访问属性,而不用slits声明则是通过key和valus这种字典的形式比较复杂,下面是,具体使用的实例:

    __slots__ = ('name','age')
    def __init__(self):   
        self.name='张三'  
        self.age=12      
stu =Student()          
print(stu.name)
# stu.age='23'
print(stu.age)

属性的私有化:

概念,属性私有化: 让当前类的私有属性不能被子类继承到
py中的私有化机制;属性名改写。在所有需要私有化的属性前添加“”则属性名会变为:类名_属性名

    def __init__(self):
        self.__name='张三'
    def __say(self):
        print('我是'+self.__name)
stu =Student()
# stu.Student__say();
print(stu._Student__name)

继承:

# __init__是初始化对象下的属性:
    def __init__(self):
        print('我是父类的init')
        self.name='张三'
    def say(self):
        print('我是基类')
# 声明继承关系:在子类名后跟小括号,小括号里是要继承的基类(父类类名)
class B(A):
# 在继承关系中init方法的执行逻辑:
# 在子类没有实现init方法时,只会触发父类中的init执行’
# 如果子类实现了init,则只触发子类的init,不会触发弗雷init执行
    def __init__(self):
        # 手动调用服了哦的init函数
        A.__init__(self)# 简单的函数调用思想此时就是将b中self作为参数传给a
        print('我是子类的init')
        # self.name='李四'
    def bSay(self):
        print('我是子类')
    # 在子类中复写父类中的方法
    def say(self):
        # 需要父类的方法,就定义一遍,不需要就不定义,定义自己的方法
        A.say(self)
        print('我是复写的新数据')
      # a=A()
    # a=A()
    b=B()
     # b.say()
     print(b.name)
上一篇下一篇

猜你喜欢

热点阅读