零基础学 Java
臧萌
PayPal 数据处理组技术负责人
46665 人已学习
新⼈⾸单¥68
课程目录
已完结/共 170 讲
第二章 Java面向对象编程 (74讲)
时长 07:13
时长 12:08
时长 06:26
时长 05:30
时长 14:16
时长 08:30
零基础学 Java
登录|注册
留言
27
收藏
沉浸
阅读
分享
手机端
回顶部
当前播放: 12 | Java中的基本数据类型
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

登录 后留言

全部留言(27)

  • 最新
  • 精选
余敏
Java整数缺省、浮点数缺省是什么意思啊?

作者回复: 缺省值,default 值,默认值三个词是一个意思。代表某种数值类型的......默认值。

2019-08-19
14
十月的天空城
补充一丢丢计算机的小知识: 由于再Java中二进制是以补码的形式表示的,所以最高位是符号位。 在计算机内,定点数有3种表示法:原码、反码和补码 [原码] 就是二进制定点表示法,即最高位为符号位,“0”表示正,“1”表示负,其余位表示数值的大小。 [反码] 表示法规定:正数的反码与其原码相同;负数的反码是对其原码逐位取反,但符号位除外。 [补码] 表示法规定:正数的补码与其原码相同;负数补码为其绝对值各位取反加1。 举个例子: +64:二进制形式为0100 0000,其补码同样也为:0100 0000 -64:二进制形式为0100 0000,取反为1011 1111 再加1后等于 1100 0000 byte为一字节8位,最高位是符号位,即最大值是0111 1111,因正数的补码是其本身,即此正数为0111 1111. 所以:byte 占用 1个字节,值域: -2^7 ~ 2^7-1 即:-128 ~ 127

作者回复: 👍👍,建议有基础的同学把这一段看懂

2021-05-12
4
Geek_88737a
老师讲课 比较清晰明了 废话也很少 如果大家有看不懂的话 我建议看两遍 基础是最重要的

作者回复: 其实我觉得我有时候废话还是挺多的囧

2020-03-23
4
坏人
为什么byte和shor后面不用加字母呢?我的理解是下面的,不知道对不对。 数字的默认类型是int,byte被包含在int里面吗?所以long的值在被包含在int的值中时可以不加L,但是超出必须要加的。 long的值在int类型中时,也是占用8bit的内存吗? java编译器会对这种类型有优化吗?

作者回复: > 为什么byte和short后面不用加字母呢? 是的, 编译器可以检查byte和short的值阈, 如果超出会报错. 比如 byte b = 999; 这个更多的是Java编译器从易用性做的一种简化. 如果每次给byte和short赋值, 都要标明一下类型, 会很繁琐. > 后面的问题... 其实不存在long的值包含在int里面, 比如 long abc = 999; 这个过程其实是一种Java的自动类型转换, 低精度的数字可以赋值给高精度的数字. 这部分内容在"15 | 基本数据类型的更多语法点"有讲述.

2019-05-21
4
4
UU
老师好,“对于boolean,官方文档未明确定义,它依赖于 JVM 厂商的具体实现。逻辑上理解是占用 1位,但是实际中会考虑计算机高效存储因素”。如何看待这段解释。

作者回复: JVM不是只能跑在高性能的服务器上,或者动则几个G的手机里,也可能跑在嵌入式设备里,跑在内存CPU很小的设备上。这时候JVM可能就值得优化了。 这就是标准的能力。标准只规定了boolean的使用规范,并不涉及其底层是怎么存储的。只要能当boolean用就行。 对于服务器之类的,当然是不在乎boolean占一个字节还是一个bit,访问的效率更重要,那就用一个byte。对于内存稀罕的,对访问速度又没什么要求的,没准可以(但是我觉得可能性也不高,寻址有问题)用一个byte表示好几个boolean。

2020-10-28
3
100执行%
为什么float 100.1111111输出来是100.11115呢 不应该是4舍5入吗

作者回复: 这个不是四舍五入的范畴,而是计算机里的浮点数(不止是Java)无法精确表示每一个小数的问题。详细参见 https://github.com/deepnighttwo/LetsJava/blob/master/FAQ/01%E7%AB%A0-%E4%B8%BA%E4%BB%80%E4%B9%88%E8%AE%A1%E7%AE%97%E6%9C%BA%E9%87%8C%E7%9A%84%E6%B5%AE%E7%82%B9%E6%95%B0%E4%B8%8D%E7%B2%BE%E7%A1%AE.md

2019-10-16
2
洋葱切丁
老师你好,java中有这么多数据类型(byte、short、int、float、double),而且都是从小到大包含的,后面写程序的时候所有的数字类型的数据都统一用double是不是可以,这样做有什么劣势?盼复,谢谢~

作者回复: double的问题在于无法精确的比较。而且有些场景可能会出现精度问题,比如本来应该是3,结果double变成了2.9999999999这都是有可能的。 由此造成的问题就是,要比较两个double的值很繁琐,要用两个double的数字相减,然后看差值的绝对值是不是小于一个对于业务足够可以忽略。比如对于表示钱的两个double数字,差的绝对值如果小于0.001,也就是一厘,那就可以认为是相等的。 如果业务上是整数,尽量用int或者long。比如表示手机的个数,汽车的个数等。

2019-05-24
2
Geek_20d27a
老师,快捷键指令大全哪里有

作者回复: 搜索“intellij 快捷键”就可以找到了

2021-11-12
2
1
一米阳光
老师,double有值域吗?是多少?

作者回复: double的值域有,但是意义不大,当表示非常大的数字时,double的精度会丢失的非常厉害。就好像你用天文望远镜看星星,测量误差可能都是光年级别的。

2021-10-22
1
张二旦
老师,大的整数是因为超过了默认的整数类型int的范围,所以要加个L表示long的数据类型,比如: long v1 = 99; //正确 long v2 = 9999999999999L; //正确 小的浮点数并没有超过默认的浮点数类型double,为什么末尾要加f表示float数据类型呢,比如: float f1 = 1.1; //报错 float f1 = 1.1f; //正确

作者回复: Java中的整数默认最多是int类型,比如9,8,99999999,最多是int类型。再想向上,就要加个L后缀,就代表是long类型。 而浮点数默认是double类型,比如1.1,所以如果要给float赋值,要加个后缀f代表是float而不是double。

2020-11-11
1
收起评论