首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

Python面向对象基础

NOTE: 重要强调:     Python的作用域和命名空间 (1)命名空间 是从命名到对象的映射     ①内置命名空间     ②全局命名空间:模块     ③本地命名空间:模块中的函数和类 (2)作用域   是一个 Python 程序可以直接访问命名空间的正文区域 一:简介             类:用来描述具有相同的属性和方法的对象的集合         方法:类中定义的函数       类变量:类变量在整个实例化的对象中是公用的。                     类变量定义在类中且在函数体之外。类变量通常不作为实例变量使用。     实例变量:定义在方法中的变量,只作用于当前实例的类。(注意区分实例变量和类变量)     实例变量用于对每一个实例都是唯一的数据,类变量用于类的所有实例共享的属性和方法     用构造方法初始化的属性叫做实例变量,直接在类中定义的属性叫做类变量。    方法重写:如果从父类继承的方法不能满足子类的需求,可以对其进行改写,这个过程叫方法的覆盖(override)        实例化:创建一个类的实例,类的具体对象            对象:通过类定义的数据结构实例     二:语法格式     class ClassName:             <statement-1>             <statement-N> 三:类对象     类对象支持两种操作:属性引用和实例化。     (1)类对象创建后,类命名空间中所有的命名都是有效属性名MyClass.f     (2)实例化:将类对象看作是一个返回新的类实例的无参数函数x = MyClass() 四:类属性     公有属性:在类中定义,可以在类间调用,可以通过析构函数进行初始化     私有属性:在类中定义,以双下划线开始,在类外不能被直接调用,只能被类内部方法使用!     调用方法:用公有方法返回! 五:类方法     (1)类的方法与普通的函数只有一个特别的区别——它们必须有一个额外的第一个参数名称,     按照惯例它的名称是 self     (2)在类的内部,使用 def 关键字来定义一个方法,与一般函数定义不同,     类方法必须包含参数 self, 且为第一个参数,self 代表的是类的实例     (3)两个下划线开头,声明该方法为私有方法,只能在类的内部调用 ,不能在类地外部调用     (4)类的专有方法 六:构造函数     类有一个名为 __init__() 的特殊方法(构造方法),     该方法在类实例化时会自动调用类有一个名为 __init__() 的特殊方法(构造方法),     该方法在类实例化时会自动调用     可以声明带默认参数的实例变量! 七:析构函数     实例化的对象调用结束时候调用! 八:类的继承         (1)语法结构         class DerivedClassName(BaseClassName1):                     <statement-1>                     .                     <statement-N>         (2)多类继承的时候,新式类(python3)按照广度优先的原则,         (找一个爸爸,再找下一个爸爸。。。。)         class DerivedClassName(Base1, Base2, Base3):                 <statement-1>                 .                     <statement-N>     (3)基类名与派生类定义在同一个作用域中,除了类,还可以用表达式,     基类定义在另一个模块中时这一点非常有用:         class DerivedClassName(modname.BaseClassName):     这种写法在模块化程序中很重要!     (4)方法重写     ①父类方法的功能不能满足你的需求,可以在子类重写你父类的方法         super(Child,c).myMethod() #用子类对象调用父类已被覆盖的方法           子类,对象, 方法     ②派生类对基类的方法重写,重写后的基类方法叫做费捆绑方法,     不能直接调用,需要使用super函数。     注意:     ①子类不重写 __init__,实例化子类时,会自动调用父类定义的 __init__。     ②重写了__init__ 时,实例化子类,就不会调用父类已经定义的 __init__     ③如果重写了__init__ 时,要继承父类的构造方法,

02

Java中的构造方法[通俗易懂]

【08-10】构造方法 定义:就是类构造对象时调用的方法,主要用来实例化对象。构造方法分为无参构造方法、有参构造方法。 概念:构方法是一种特殊的“成员方法” 1,构造方法作用:(1)构造出来一个类的实例 (2)对构造出来个一个类的实例(对象)初始化 2,构造方法的名字必须与定义他的类名完全相同,没有返回类型,甚至连void也没有 3,主要完成对象的初始化工作,构造方法的调用是在创建一个对象时使用new操作进行的 4,类中必定有构造方法,若不写,系统自动添加无参构造方法。接口不允许被实例化,所以接口中没有构造方法 5,不能被static、final、synchronized、abstract和native修饰 6,构造方法在初始化对象时自动执行,一般不能显式地直接调用. 当同一个类存在多个构造方法时,java编译系统会自动按照初始化时最后面括号的参数个数以及参数类型来自动一一对应 完成构造函数的调用] 7,构造方法可以被重载。没有参数的构造方法称为默认构造方法,与一般的方法一样,构造方法可以进行任何活动 但是经常将他设计为进行各种初始化活动,比如初始化对象的属性 8,构造代码块:     (1)作用:给对象进行初始化,对象一建立就执行,而且优先于构造函数执行   (2)构造代码块和构造函数的区别:    构造代码块是给所有不同对象的共性进行统一初始化,构造函数是给对应的对象进行初始化 9,自定义类中,如果不写构造方法,java系统会默认添加一个无参的构造方法。 如果写了一个有参的构造方法,就一定要写无参构造方法。一般情况下,我们自定义的类都要手动给出无参构造方法。

03

Java学习历程之----提升篇(三)

贝赫和斯维讷通-戴尔猜想:指的是对有理数域上的任一椭圆曲线, 其L函数在1的化零阶等于此曲线上有理点构成的Abel群的秩。数学家总是被诸如X**2+Y**2=Z**2这样的代数方程的所有整数解的刻画问题着迷。欧几里德曾经对这一方程给出完全的解答,但是对于更为复杂的方程,这就变得极为困难。事实上,正如马蒂雅谢维奇指出,希尔伯特第十问题是不可解的,即不存在一般的方法来确定这样的方法是否有一个整数解。当解是一个阿贝尔簇的点时,贝赫和斯维讷通-戴尔猜想认为,有理点的群的大小与一个有关的蔡塔函数z(s)在点s=1附近的性态。特别是,这个有趣的猜想认为,如果z⑴等于0,那么存在无限多个有理点(解),相反,如果z⑴不等于0,那么只存在有限多个这样的点。

01

java基础学习_面向对象(下)01_day08总结

============================================================================= ============================================================================= 涉及到的知识点有: 1:继承(掌握)   (0)Java继承概述   (1)继承定义   (2)Java中如何表示继承呢?格式是什么呢?   (3)继承的好处   (4)继承的弊端     A:让类的耦合性增强。这样某个类的改变,就会影响其他和该类相关的类。     B:打破了封装性。   (5)Java中继承的特点   (6)继承的注意事项     A:Java中类只支持单继承,不支持多继承。     B:Java中可以多层(重)继承(继承体系) (7)那么什么时候使用继承呢?     A:继承体现的是:is a的关系。     B:采用假设法。 (8)Java继承中的成员关系     A:成员变量     B:构造方法     C:成员方法 (9)方法重写:(方法=成员方法)   (10)方法重写的两个面试题     A:Override和Overload的区别?Overload是否可以改变返回值类型?     B:this和super的区别和各自的作用? (11)数据初始化的面试题     A:一个类的初始化过程     B:子父类的构造执行过程     C:子父类的初始化(分层初始化) (12)继承案例     A:学生和老师案例     B:猫狗案例的分析和实现 ============================================================================= ============================================================================= 1:继承(掌握) (0)Java继承概述 (1)继承定义:把多个类中相同的成员给提取出来定义到一个独立的类中。然后让这多个类和该独立的类产生一个关系,这多个类就具备了这些内容。这个关系叫继承。 (2)Java中如何表示继承呢?格式是什么呢? A:用关键字extends表示。 B:格式:       class 子类名 extends 父类名 {} --------------------------------------- (3)继承的好处: A:提高了代码的复用性。 B:提高了代码的维护性。 C:让类与类之间产生了一个关系,是多态的前提。       类与类产生了关系,其实也是继承的一个弊端:         类的耦合性增强了。 --------------------------------------- (4)继承的弊端: A:让类的耦合性增强。这样某个类的改变,就会影响其他和该类相关的类。       开发设计的原则:低耦合,高内聚。         耦合:类与类之间的关系。         内聚:自己完成某件事情的能力。 B:打破了封装性。       因为我们曾经说过:一个类中的成员尽量不要让外界直接访问,子类继承父类后,那么父类的封装就被打破了。 --------------------------------------- (5)Java中继承的特点: A:Java中类只支持单继承,不支持多继承。       即:一个类只能有一个父类,不可以有多个父类。       class Father {}       class Mother {}       class Son exnteds Father {}   //正确的       class Son extends Father,Mother {}   //错误的       有些语言是支持多继承的额,比如c++。其格式是:extends 类1,类2,... B:Java中可以多层(重)继承(继承体系)       class A {}       class B extends A {}       class C extends B {} --------------------------------------- (6)继承的注意事项:     A:子类不能继承父类的私有成员(成员变量和成员方法)。       其实这也体现了继承的另一个弊端:打破了封装性。       因为我们曾经说过:一个类中的成员尽量不要让外界直接

02
领券