零基础学 Java
臧萌
PayPal 数据处理组技术负责人
46665 人已学习
新⼈⾸单¥68
课程目录
已完结/共 170 讲
第二章 Java面向对象编程 (74讲)
时长 07:13
时长 12:08
时长 06:26
时长 05:30
时长 14:16
时长 08:30
零基础学 Java
登录|注册
留言
23
收藏
沉浸
阅读
分享
手机端
回顶部
当前播放: 47 | 分清参数、局部变量和实例的地盘
00:00 / 00:00
高清
  • 高清
1.0x
  • 2.0x
  • 1.5x
  • 1.25x
  • 1.0x
  • 0.75x
  • 0.5x
网页全屏
全屏
00:00
付费课程,可试看
01 | 课程介绍
02 | 内容综述
03 | 开发环境搭建(macOS)
04 | HelloWorld程序编译和运行(macOS)
05 | 开发环境搭建(Windows)
06 | HelloWorld程序编译和运行(Windows)
07 | 详解HelloWorld程序
08 | IntelliJ IDEA集成开发环境的安装和使用(macOS)
09 | IntelliJ IDEA集成开发环境的安装和使用(Windows)
10 | 从加减乘除到变量
11 | 再探计算加减乘除的程序
12 | Java中的基本数据类型
13 | Java中的运算符
14 | Java中的位运算符
15 | 基本数据类型的更多语法点
16 | 字符集编码和字符串
17 | 操作符和数据类型总结
18 | 程序执行流程之if-else语句(上)
19 | 程序执行流程之if-else语句(下)
20 | 程序循环之for语句
21 | 代码块和变量的作用域
22 | 程序循环之while语句
23 | 程序执行流程之switch语句
24 | 循环和判断的总结(上)
25 | 循环和判断的总结(下)
26 | 用数组保存成绩
27 | 认识变量和数组(上)
28 | 认识变量和数组(下)
29 | 多维数组
30 | 用数组灵活处理程序
31 | 类(class)
32 | 初探类和对象
33 | 认识引用类型(上)
34 | 认识引用类型(下)
35 | 类、对象和引用的关系
36 | 认识数组类型
37 | 引用的缺省值null
38 | 像自定义类型一样使用类
39 | Java中的包和访问修饰符(上)
40 | Java中的包和访问修饰符(下)
41 | 打造一个小超市
42 | IntelliJ调试程序初探
43 | 方法:让Merchandise对象有行为
44 | 返回值:让Merchandise计算毛利润
45 | 参数:让Merchandise计算多件商品的总价
46 | 参数和返回值是怎么传递的
47 | 分清参数、局部变量和实例的地盘
48 | 隐藏的this自引用
49 | 理解方法:一种特殊的代码块
50 | 理解方法的调用:代码的一种特殊跳转
51 | 给类和方法加Java注释
52 | 成熟的类的对象要自己做事情
53 | 方法的签名和重载
54 | 重载的参数匹配规则
55 | 构造方法:构造实例的方法
56 | 构造方法的重载和互相调用
57 | 静态变量
58 | 静态方法
59 | 静态方法的重载
60 | static代码块和static变量初始化
61 | 方法和属性的可见性修饰符
62 | 重新认识老朋友:Math和Scanner(上)
63 | 重新认识老朋友:Math和Scanner(下)
64 | 最熟悉的陌生人:String (上)
65 | 最熟悉的陌生人:String (下)
66 | 重新认识老朋友: main方法和System类
67 | String类的好兄弟
68 | 继承:方便让商品增加新的类别
69 | 子类对象里藏着一个父类对象
70 | 覆盖:子类想要一点不一样
71 | super:和父类对象沟通的桥梁
72 | super:调用父类的构造方法
73 | 父类和子类的引用赋值关系
74 | 多态:到底调用的哪个方法?(上)
75 | 多态:到底调用的哪个方法?(下)
76 | 多态里更多的语法点(上)
77 | 多态里更多的语法点(下)
78 | instanceof操作符
79 | 继承专属的访问控制:protected
80 | final修饰符(上)
81 | final修饰符(下)
82 | 继承里的静态方法
83 | 插曲:for循环的另一种写法
84 | 万类之祖:Object类
85 | hashCode和equals 方法(上)
86 | hashCode和equals 方法(下)
87 | toString方法
88 | 初探Class类
89 | 初探反射(上)
90 | 初探反射(下)
91 | 面向对象三要素:封装、继承和多态
92 | 枚举:定义商品的门类
93 | 接口:让商品类型更丰富(上)
94 | 接口:让商品类型更丰富(下)
95 | 抽象类:接口和类的混合体
96 | 有方法代码的接口
97 | 接口内代码的更多内容
98 | 静态内部类
99 | 成员内部类
100 | 局部内部类
101 | 匿名类
102 | 特殊类的总结
103 | 让我们的超市运转起来:设计篇
104 | 让我们的超市运转起来:代码篇
105 | 初识异常:try catch
106 | Java中异常的分类
107 | 抛出异常的语法
108 | Java异常的传递
109 | 自定义异常
110 | 异常传递不是凌波微步
111 | try catch finally语句
112 | 自动回收资源的try语句
113 | Java中的常见异常
114 | Collection类族简介
115 | Collection中的List (上)
116 | Collection中的List(下)
117 | Collection中的Set
118 | 泛型简析(上)
119 | 泛型简析(下)
120 | 再探泛型
121 | Iterator接口
122 | Map:key和value的映射
123 | 定义自己的注解
124 | Lambda V.S. 匿名类(上)
125 | Lambda V.S. 匿名类(下)
126 | 基本类型的自动装箱和拆箱
127 | Java中的File类
128 | Java I/O简介
129 | 写文件内容小程序
130 | 读文件内容小程序
131 | 网络通讯名词简介
132 | 简单的网络通讯小程序(上)
133 | 简单的网络通讯小程序(下)
134 | 简单的抓取网页内容的程序
135 | JDK和JRE
136 | 初识线程
137 | 创建自己的线程
138 | 再探线程
139 | 多线程:混乱开始了
140 | 同步控制之synchronized
141 | 同步控制之wait notify
142 | 多线程经典模型:生产者消费者
143 | 线程同步之join
144 | 死锁
145 | ThreadLocal线程专属的变量
146 | 定时任务
147 | volatile关键字的作用
148 | concurrent包基本原理
149 | concurrent包中的Atomic类族
150 | concurrent包中的锁
151 | concurrent包中的数据结构
152 | concurrent包中的线程池
153 | 聊天室开张喽 (上)
154 | 聊天室开张喽 (下)
155 | 什么是学习一门语言
156 | Java平台简介
157 | Maven概念简介
158 | Maven的安装和配置
159 | 创建一个简单的Maven项目
160 | 一个从pptx文件中抽取文字的小工具
161 | Maven常用命令和插件
162 | Intellij更多功能介绍
163 | 值得学习的类库简介
164 | 如何在Stack Overflow上提问才不会被骂
165 | 浅谈程序设计
166 | 游戏小程序功能定义
167 | 游戏小程序设计和模块划分
168 | 游戏小程序代码分析
169 | 使用Swagger创建一个Spring Boot的Web服务
170 | 结课测试&结束语
本节摘要

PDF 课件和源代码下载地址:
https://gitee.com/geektime-geekbang/LetsJava

登录 后留言

全部留言(23)

  • 最新
  • 精选
飞鱼
老师,请问上面说“方法里面创建的对象不会随方法的结束而清除”,比如下面这个方法中 { Book b = new Book(); } 当方法结束后,b就消失了,那就没有引用指向这个对象,为什么这个对象不会跟着清除呀?

作者回复: 我要表达的意思是,创建对象的方法结束了,并不是这个方法里创建的对象被消除的充分条件。当然也不是必要条件。也就是说创建某个对象的方法执行是否结束,和这个对象是否会被清除,一点关系都没有。 先说不是必要条件,以你的代码为例,如果是指向这个对象唯一的引用,那么在后面加上一行b=null,这个对象也就没有引用指向它了。在方法执行完之前,这个对象就可以被清除掉。 再说不是充分条件。b并不一定是指向这个对象的唯一引用。在Book的构造方法里,完全可以把自己的引用放在别的对象的成员变量里,或者加到一个静态的list里。所以方法结束之后完全可以有别的引用指向这个对象。 所以,没有引用指向一个对象,那么这个对象铁定可以被清除。这个创建这个对象的方法是否执行完毕没有任何关系。

2019-10-12
6
14
hao-kuai
老师,只要值可以修改都叫变量吧,变量应该是和常量概念相对应吧。

作者回复: 这个可能需要从不同的角度去理解。 变量的英语叫做variable,variable的词根vary就是变化,使得=多样化的意思。 到了计算机这边,variable(变量)就泛指一个有名字的值了。至于能不能变化,倒是其次的。与其对应的,更多的可能是literal value(字面值)。literal value只有值,没有名字,是一种更绝对的“常量”。 至于常量,可以认为是变量中特殊的一种,也就是值不可变化。这个就有点矛盾,本身叫变量,而又不能变化。其实Java中的常量,声明的语法如下: final int variableInt = 9; 也就是说,常量是使用final修饰的变量。 这些都是比较偏虚的,类似考试一样的问题。其实在实际编程使用中,只要说变量,常量,字面值就可以。理解每种概念的含义,不用纠结谁是谁的对应面。

2019-06-07
5
因为热爱
// >> TODO 给返回值赋值,并不会影响用来充当返回值的变量 MerchandiseV2 giftOfM; // >> TODO 可以通过返回值,操作同一个对象 System.out.println("获取m的赠品,并修改这个赠品对象的采购价格"); System.out.println("修改前"); m.describe(); giftOfM = m.getGiftAndHowCanOutsideChangeIt(); giftOfM.purchasePrice = giftOfM.purchasePrice * 10; System.out.println("修改后"); m.describe(); //////////////// 以上是老师的一段代码 其中 MerchandiseV2 giftOfM; //这一句的意思是我创建了一个商品类的引用 giftOfM = m.getGiftAndHowCanOutsideChangeIt(); //这一句话的意思是这个引用等于这个方法,而这个方法呢,也是一个商品类,所以他们之间可以相等。而这个giftOfM 指向的是这个方法里的返回值 gift 这个gift的属性也是一个商品类。这段代码再翻译一下也可以是:giftOfM=m.gift。 下一段代码: giftOfM.purchasePrice = giftOfM.purchasePrice * 10; //这一段代码的意思就是把 gift这个商品类里的价格变量的值*10倍。 此时我们就已经修改完成类 那么我也写了一段代码 也完成了老师之前的那个操作 MerchandiseV2 mm; mm=m.gift; mm.purchasePrice*=10; m.describe(); 老师你看对不对,还有上面我理解的哪里有一些问题

作者回复: 完全正确✅

2020-10-01
2
3
森森
我觉得老师的课真是让我重新从底层认识了一遍Java,这是我在极客选择的最超预期的课,老师加油~

作者回复: 谢谢~,你也加油哦

2020-03-24
3
就是故意丶
其实是个两三年的程序员了。。总被吐槽基础不扎实,老老实实一下一下的看过来的,发现作者讲的很生动形象,很明白,为啥只有不到两千的销量呢。。。。。。

作者回复: 扎心了老铁! 为了大家夯实基础,票圈分享起来,两千达成就靠你了~

2019-09-27
2
2
蓦然回首
像C++里面有按值,引用和地址传递三种,其中除了按值传递不能改变实参本身外,其他两种都可以做到,那java里面有类似的机制可以直接改变实参吗?

作者回复: 没有,只有按值传递。

2020-10-31
1
蓦然回首
老师,这两节课讲到了引用数据类型和基本数据类型通过类方法传递是否能改变实参类型的问题: 我本人目前从事的是C/C++开发的工作,看到老师对于引用类型的解释和指针很像,除了java里面没有指针这个概念外,基本特性很像: 比如: 1、指针通过new分配内存,默认方式也是在堆上面(当前可以重载new运算符,不过我们这里只说默认方式) 2、引用和指针指向的对象(通过new创建),都是在当前作用域内不会像局部变量,离开自己的作用域后会被自动释放掉 当然,看到下面其他同学的提问,老师的回答,当没有引用指向对象实体的时候,对象会被清除掉,这点很像C++里面的智能指针,应该是Java里面的垃圾回收机制做的工作吧,不过C++里面没有自动的垃圾回收机制 3、还有像传递参数的时候,指针和引用,直接作为参数传递的时候,都类似于普通基本数据类型一样,类似于拷贝了一个副本,形参的改变并不能影响实参本身的值,只不过,我们可以利用引用和指针在方法内部改变指针和引用指向的对象 以上是我的一点见解,说的并不全面

作者回复: 说到语言的功能,和C++比Java是弟弟(除了多了内存自动收集)。

2020-10-31
1
Geek_b597bc
public void changeToTheSameGift(MerchandiseV2 m2) { m2.gift = gift; } m.changeToTheSameGift(paramRef); 这行代码相当于paramRef.gift = gift,但是后面的gift从哪里来呢,为什么后面的就是m.gift了呢?

作者回复: gift是当前对象的成员变量。相当于是this.gift

2020-07-28
3
1
董飞
老师,您的书用的是java几,语法会不会和现在不太一样?在哪里可以买?

作者回复: 那本书的内容和这个视频都是Java基础,没必要重续买。

2020-03-29
1
bestRktnZnnn
老师,如果m1有一个gift,m2也有一个gift,现在只想改变m2的gift的某个属性而不影响m1的gift,怎么操作呢

作者回复: 让m1和m2的gift指向不同的对象,就不会互相影响了

2023-04-08
收起评论