zoukankan      html  css  js  c++  java
  • MOOC 浙江大学 面向对象程序设计-Java 笔记(1)

    中国大学MOOC 浙江大学 面向对象程序设计-Java语言
    ------------翁恺老师授课
    第一次课程 类与对象

    摘要

    类与对象
    类: 类是规范,根据类的定义来创建对象。
    对象: 对象是实体,需要被创建。可以使用类的定义制造很多个对象出来。每一个对象会有不同的属性,有相同的操作。对象是类的一个个具体的实例。
    在类中定义的变量,在每一个对象中存在。
    这只猫----->对象
    猫这种动物------->类
    对象 = 属性 + 服务
    数据:属性或状态
    操作:函数

    定义类

    类由表示对象有什么的成员变量表示对象能做什么的成员函数 组成。

    结束定义类后,需要制造对象,并将其交由对象变量管理(对象变量只是对象的管理者而非所有者)。

    <类> 对象变量 = new 类();
    <-------------------------
    至此,对象变量可以调用类中的函数( . 运算符)。
    同时制造多个同类型的对象后,每一个对象的id均不相同。若id 相同代表的是相同的对象。

    不同的 id 值

    观察new 类()时发现: 先给this一个 id 值,再将这个 id 值给对象变量管理。注意下面两图中的 id

    在这里插入图片描述
    在这里插入图片描述

    成员变量与成员函数

    关键:理解类的定义和对象的关系,理解对象中的成员变量是怎么来的,怎么就能让成员函数明白自己在和哪个对象打交道?


    1. 类里的成员变量,只是一个声明,变量并不在那里,变量不在类里,变量在每一个对象里。(难呀难)对象中的成员变量生存周期是对象的生存期,作用域是类内部的成员函数。
    2. 如何让成员函数知道自己需要处理哪个对象的数据呢?---好帮手 this

    对象变量1.类内方法
    --- 将对象变量1的 id 值交给 this, this再告诉成员函数:“你这次需要操作 id为? 的对象的数据 ”。
    (1) this 是成员函数的一个特殊的固有的本地变量,表达了调用这个函数的那个对象。this 会随对象变量变化而变化。

    (2) 在函数中可以直接写成员变量的名字来访问成员变量,因为对象在调用时会写明是哪一个对象变量( id )。
    --------- 问题又出现了,如果函数的变量名 num (代号A)与类内成员变量名 num (代号B) 相同时,怎么处理数据呢??
    函数内定义的变量其作用域是这个函数,在这个函数内部,提到 num 均 是 A。如果也想在这个函数内使用成员变量 num 怎么办?使用 this 关键字,this.num 指这个对象内的成员变量num。

    (3) 在成员函数内部直接调用自己(this)的其他函数,此时不需要用this。

    对象初始化

    对象初始化,按顺序初始化类内成员变量,但如果类内有构造函数(构造函数与类同名,不能有任何返回值)时,初始化过程为:
    (1)new <类>();
    (2)进入类内构造函数声明所在行(此时并不会进入构造函数内部)
    (3)离开构造函数,去成员变量声明处(类里的成员变量,只是一个声明),按顺序初始化成员变量,最后再进入构造函数,再离开类。

    方法重载

    如果有两个方法的名称相同,但参数列表不一致--重载。
    根据参数类型决定调用其不同版本,但若参数类型没有匹配上,可自动转换。
    重载时选择合适的目标方法顺序如下:

    1. 精确匹配
    2. 基本类型数据,自动转换成更大表示范围的基本类型(int可以传进int或者double,而double只能传进double)
    3. 通过自动拆箱与装箱
    4. 通过子类向上转型继承路线的一次匹配
    5. 通过可变参数匹配
      目前后三种还未涉及,学习中......

    随着课程的深入,后续会继续完善和修改此部分知识点。
    加油ヾ(◍°∇°◍)ノ゙

  • 相关阅读:
    ROM、RAM、DRAM、SRAM和FLASH的区别
    寄存器读写为什么需要用位操作符
    不同变量存放在什么地方
    C语言中数据类型对变量的作用
    内存寻址、对齐,变量左值和右值
    位、字节、半字、字、内存位宽
    面试题10- II. 青蛙跳台阶问题
    509. 斐波那契数
    面试题10- I. 斐波那契数列
    面试题32
  • 原文地址:https://www.cnblogs.com/yuecheng/p/12568905.html
Copyright © 2011-2022 走看看