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

登录 后留言

全部留言(11)

  • 最新
  • 精选
Noya
萌老师, java入门123 第 127页, gradeStudents[1]=classTwo 之后, 原本的 gradeStudents[1] 所指向的实体就无从寻找了, 怎么把那一边空间释放掉呢, 还是这就是java的内存回收机制, 可以自动回收

作者回复: Java自动垃圾回收的。

2020-06-08
4
let_me_go
老师对于isFile方法,我不太理解 在你给的代码中,这个isFile方法可以理解为,在该目录下是否已经创建了同名的文件,但是我看了对isFile方法源代码的注释以后,就有些懵懵的。 File f = new File("." + File.separator + fileName + ".txt"); if (f.isFile()) { System.out.println("目标文件存在,删除:" + f.delete()); } 源代码里面的解释: Tests whether the file denoted by this abstract pathname is a normal file. A file is normal if it is not a directory and, in addition, satisfies other system-dependent criteria. Any non-directory file created by a Java application is guaranteed to be a normal file. Return true: if and only if the file denoted by this abstract pathname exists and is a normal file 直译过来就是: 测试由这个抽象路径名表示的文件是否是一个普通文件。如果文件不是目录,并且满足其他与系统相关的条件,那么它就是正常的。Java应用程序创建的任何非目录文件都保证是正常的文件。 当且仅当此抽象路径名所表示的文件存在且为正常文件时 看它的这个解释,我不太懂,是不是可以这样理解: 当对象指向一个文件时,若要新建文件,则可以用来判断该路径下是否存在同名文件,若存在同名文件则返回true 当对象指向一个路径时,若要新建路径,则可以用来判断是否存在完全同名的路径,若存在完全相同的路径也返回true

作者回复: 首先,查看文档是个很好的习惯~ isFile用了判断一个路径是不是一个普通的文件。isDirectory()用来判断路径是不是一个文件夹。Java里文件和文件夹都是用File类表示的,略有迷惑熟悉。

2020-02-28
3
安东
// TODO 创建一个inputstream,建立一个从文件到程序的byte数据传输流 FileOutputStream fos = new FileOutputStream(targetFile); 老师为什么FIleOutputsStream是inputstream呢?

作者回复: 应该是output stream,谢谢活捉bug一只 https://github.com/deepnighttwo/LetsJava/blob/master/%E7%AC%AC%E5%9B%9B%E7%AB%A0%20Java%20%E4%B8%AD%E7%9A%84%E5%B8%B8%E7%94%A8%E5%B7%A5%E5%85%B7%E7%B1%BB%E5%92%8C%E6%96%B0%E8%AF%AD%E6%B3%95/13.%20%E5%86%99%E6%96%87%E4%BB%B6%E5%86%85%E5%AE%B9%E5%B0%8F%E7%A8%8B%E5%BA%8F/code/src/com/geekbang/learntowrite/WriteToFilesAppMain.java#L24-L26 https://github.com/geektime-geekbang/LetsJava/pull/4

2019-11-26
2
3
我爱夜来香
老师,还是没体会到FileOutputStream和OutputStreamWriter的区别,我发现去掉OutputStreamWriter转换成字符流后,直接用字节流写到文件,也没啥区别呀?老师能讲讲有啥区别吗?

作者回复: 一个是面向字节的,一个是面向字符的。两者都可以向文件写数据。

2022-04-15
1
追光
FileOutputStream是按字节流输出 OutputStreamWriter是把字符串输出 是这样吗

作者回复: 嗯呐

2021-11-24
1
追光
老师,try-with-resource是不是视频里没讲

作者回复: 有讲,慢慢看

2021-11-24
Geek_ba25c6
谢谢,今天你说的那个修改版本的方法解决了很多问题,这节代码里面的那个,while循环中,if(line To Write.trim().isBank())报错,说找不到isBank()。然后我看了下spring类的trim()方法中,确实没找到

作者回复: isBlank是string类的方法。trim返回的是个string

2021-08-10
3
笨笨
老师如果把代码里的createNewFile()改成createFile()可以吗?

作者回复: File类里没有createFile这个方法哦

2020-11-22
稍后重试
老师好,我关于这一节查了资料在深入了一下,有个问题比较困扰,麻烦解答一下,谢谢 System.out其实就是PrintStream的一个对象,但是PrintStream类在构造的时候可以用类似这样的构造往文件输出PrintStream pu=new PrintStream(new FileOutputStream(new File("文件路径test.txt"))); 我不明白的在于为什么System.out.print就可以像显示器输出了?麻烦详细解答下,我觉得这个是不是跟ByteArrayOutputStream有关?

作者回复: Stream只是数据管道,具体数据到哪里要看数据最终操作的什么。比如FileOutputStream就是操作文件的。 为什么sout可以输出到控制台,可以看看System类里是怎么给out赋值的。

2019-09-20
3
小鹏
老师好,我想问一下,把下面三行: FileOutputStream fos = new FileOutputStream(targetFile); OutputStreamWriter osw = new OutputStreamWriter(fos, StandardCharsets.UTF_8); PrintWriter pw = new PrintWriter(osw); 换成下面两行: FileWriter fw = new FileWriter(targetFile); PrintWriter pw = new PrintWriter(fw); 这样改动后,有没有什么区别?我运行起来后都是一样的效果。 //新的代码如下 import java.io.*; import java.util.Scanner; public class WriteToFilesAppMain { private static final Scanner in = new Scanner(System.in); public static void main(String[] args) throws IOException { File targetFile = createFile(); writeToFile(targetFile); System.out.println("程序执行结束"); } private static void writeToFile(File targetFile) throws IOException { try ( FileWriter fw = new FileWriter(targetFile); PrintWriter pw = new PrintWriter(fw); ) { System.out.println("输入的内容会实时写入文件,如果输入空行则结束"); while (true) { String lineToWrite = in.nextLine().trim(); System.out.println("输入内容为" + lineToWrite); if (lineToWrite.trim().isEmpty()) { System.out.println("输入结束"); break; } else { pw.println(lineToWrite); pw.flush(); } } } catch (Exception ex) { ex.printStackTrace(); } } private static File createFile() throws IOException { System.out.println("请输入文件名:"); String fileName = in.nextLine().trim(); File f = new File("." + File.separator + fileName + ".txt"); if (f.isFile()) { System.out.println("目标文件存在,删除:" + f.delete()); } System.out.println(f.createNewFile()); return f; } }

作者回复: 没有指定Charset,系统会使用默认的charset。中文的Windows上一般会是GBK。在系统默认charset都是GBK的系统上没问题,如果系统的Charset不是GBK,就可能会有乱码。

2019-07-27
收起评论