下载APP
登录
关闭
讲堂
算法训练营
Python 进阶训练营
企业服务
极客商城
客户端下载
兑换中心
渠道合作
推荐作者
当前播放: 25 | 循环和判断的总结(下)
00:00 / 00:00
标清
  • 标清
1.0x
  • 2.0x
  • 1.5x
  • 1.25x
  • 1.0x
  • 0.5x
网页全屏
全屏
00:00
付费课程,可试看

零基础学Java

共170讲 · 170课时,约1500分钟
2657
免费
01 | 课程介绍
免费
02 | 内容综述
免费
03 | 开发环境搭建(macOS)
免费
04 | HelloWorld程序编译和运行...
免费
05 | 开发环境搭建(Windows)
免费
06 | HelloWorld程序编译和运行...
免费
07 | 详解HelloWorld程序
08 | IntelliJ IDEA集成开发环...
09 | IntelliJ IDEA集成开发环...
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和Sc...
63 | 重新认识老朋友:Math和Sc...
64 | 最熟悉的陌生人:String ...
65 | 最熟悉的陌生人:String ...
66 | 重新认识老朋友: main方...
67 | String类的好兄弟
68 | 继承:方便让商品增加新的...
69 | 子类对象里藏着一个父类对...
70 | 覆盖:子类想要一点不一样
71 | super:和父类对象沟通的...
72 | super:调用父类的构造方...
73 | 父类和子类的引用赋值关系
74 | 多态:到底调用的哪个方法...
75 | 多态:到底调用的哪个方法...
76 | 多态里更多的语法点(上)
77 | 多态里更多的语法点(下)
78 | instanceof操作符
79 | 继承专属的访问控制:prot...
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 | 同步控制之synchronize...
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创建一个Spri...
170 | 结束语
本节摘要

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

精选留言(10)

  • 2019-06-03
    最后说的比着老师的程序抄十遍,应该是认真的吧

    作者回复: 如果是之前没有编程经验的同学,我是认真的。
    编程要培养感觉,看懂学会不等于会用,抄十遍和锻炼身体一样,有一定的重复,才能形成本能。而且,在抄的时候,要一边写一边想为什么。这才是目的。目的是抄几遍之后,自己能够想着写出来,更进一步,可以对其中的代码进行改善。这才是消化吸收的过程。

    3
  • 2019-11-13
    老师,您这行代码我能求出来,但不明白他的原理?您能讲解下吗?
    int mod = rangeEnd - rangeStart; // 两数差
    int bigRandom = (int)(Math.random() * rangeEnd * 100); //这一步的用意是什么呢?乘100和乘1000有区别码?
    int unmberToGuess = (bigRandom % mod) + rangeStart; // 为什么bigRandom % mod 的值的原理是什么呢?
    展开

    作者回复: int bigRandom = (int)(Math.random() * rangeEnd * 100); //首先,Math.random()是一个从0到1的数字,所以,肯定要乘以一个大点的整数,才能保证随机性。比如说,如果rangeEnd是60,Math.random()是0.001,那么结果就是0.6了,强转整数就是0了。这个程序这么看可能更好理解:(int)(Math.random() * 100 * rangeEnd),那么Math.random() * 100就是一个从0到100的随机数,再乘以rangeEnd,那么就是一个从0到rangeEnd*100的随机数了。
    int unmberToGuess = (bigRandom % mod) + rangeStart; //理解了上面的,下面就好理解了,rangeStart是保证了最小数,bigRandom % mod是让这个从0到rangeEnd*100的随机数变成一个从0到mod的随机数,也就是从0到rangeEnd - rangeStart,两者加在一起就是一个从rangeStart到rangeEnd 的随机数了。

    当然这不是唯一的方法,这几行code就是要做到两点:
    1:得到一个从rangeStart到rangeEnd的整数
    2:这个数足够随机

    你可以试着想想别的方法

  • 老师,为什么要用这么多得布尔值去做判断呢,如果不加这些判断会有什么问题

    作者回复:
    每个判断都有其作用呀。你可以给个代码,我们来看看这个判断是什么作用。

    2
  • 2019-08-16
    老师好,scanner输入后,按Alt+Enter 键没有,import class怎么调出来这个功能?

    作者回复: 这个是IntelliJ默认的快捷键,如果你没有改过&&类名输入正确的情况下,最多稍微等等,IntelliJ就能反应过来。

  • 2019-08-16
    老师好,我是新来的学生,一直没想明白代码的一段
    int numberToGuess=((int)rangNum*randEnd*100)%mod;
    这段代码为啥不用随机数rangNum*1000替代?随机数乘以任何大数,不都是放大几倍的随机数吗?

    作者回复: 随机数可能是从0到1的double,rangNum*1000是从0到1000的随机数,但是numberToGuess有个最小值的,不能从0开始。

  • 2019-08-10
    接上条留言,以下是测试类的代码:

    import java.util.InputMismatchException;
    import java.util.Scanner;

    public class TestGuy {
        public static void main(String[] args) {
            createGuy();
        }
        static Scanner sc = new Scanner(System.in);
        private static void createGuy() {
            System.out.print("请输入名字:");
            String name = sc.nextLine();
            Guy guy = new Guy(name);
            System.out.println("创建 " + guy.getName() + " 成功!");

            while (true) {
                System.out.println("是否需要输入年龄数据?回复\"Y\"开始输入,回复\"N\"取消输入。");
                String answer = sc.nextLine();
                if (answer.trim().equalsIgnoreCase("y")) {
                    while (true) {
                        System.out.println("请输入年龄。");
                        try {
                            int age = sc.nextInt();
                            guy.setAge(age);
                            System.out.println("输入成功!" + guy.getName() + " 的年龄是 " + guy.getAge() + "岁");
                            break;
                        } catch (InputMismatchException e) {
                            System.out.println("年龄数据类型为 int,请重新输入。");
                            sc.nextLine();
                        }
                    }
                    break;
                } else if (answer.trim().equalsIgnoreCase("n")) {
                    System.out.println("取消输入。");
                    break;
                }
            }

            System.out.println("请问 " + guy.getName() + "是否有喜欢的动物?");

            while (true) {
                System.out.println("回复\"Y\"开始输入动物名称,回复\"N\"取消。");
                String answer = sc.nextLine();
                if (answer.trim().equalsIgnoreCase("y")) {
                    System.out.println("请输入动物名称:");
                    String animal = sc.nextLine();
                    guy.setFavAnimal(animal);
                    System.out.println("输入成功!" + guy.getName() + " 喜欢的动物是 " + guy.getFavAnimal());
                    break;
                } else if (answer.trim().equalsIgnoreCase("n")) {
                    System.out.println("取消输入。");
                    break;
                }
            }
        }
    }
    展开

    作者回复: scanner相当于是缓存了从命令行输入的字符,然后通过nextXxx去消费这些字符。

    nextLine会读取到换行符。但是nextInt会读取到不是数字为止。所以换行符没有被消费。所以下次调用nextLine的时候就会消费这个换行符。就好像人输入了一个空行一样。

    解决方法就是用nextLine读取一行,然后用Integer.parseInt把字符串解析成数字

  • 2019-08-10
    老师好,我遇到了一个问题。代码太长了我等一下再新建一条留言重新发,先说一下我遇到的问题。

    在运行那段代码后,按照提示输入,然后在输入完年龄后,会打印出来下面这些内容:

    输入成功!peter 的年龄是 34岁
    请问 peter是否有喜欢的动物?
    回复"Y"开始输入动物名称,回复"N"取消。
    回复"Y"开始输入动物名称,回复"N"取消。

    这里的「回复"Y"开始输入动物名称,回复"N"取消。」被打印了两次,不知道是为什么?(代码会在另外的留言中发出)
    展开
  • 2019-07-07

    if (guess > numberToGuess) {
                        System.out.println("输入的数字比目标数字大");
                    } else if (guess < numberToGuess) {
                        System.out.println("输入的数字比目标数字小");
                    } else {
                        correctGuessCount++;
                        correctGuess = true;
                        System.out.println("输入的数字正确!");
                        break;

                    }
                }
    if (!correctGuess) {
                    System.out.println("本次的目标数字是" + numberToGuess);
                }
    为什么if里面是!,if语句后面是true会执行语句体,但是题中Boolean的默认值是false,
    根据题中要求当所有5次输入都错误时,输出目标数字,如果correctGuess是取非,就是true,不就代表其中一次输入是正确的的,为什么if语句会成立呢?
    展开

    作者回复: 如果猜对了, 会给它赋值,不会用缺省值的
                        correctGuess = true;

  • 2019-07-06
    判断小的时候,比较值写错,已找到原因,谢谢

    作者回复: 手动点赞👍

  • 2019-07-06
    为什么照着写,还是返回:
    请输入猜测的数字:在(30,50)之间
    43
    输入的数字比目标数字大
    请输入猜测的数字:在(30,50)之间
    42
    输入的数字比目标数字小
    请输入猜测的数字:在(30,50)之间

    看不出来错在哪里,确实转换成了int类型,老师求救
    展开

    作者回复: 刚刚看到,问题审核会需要些时间。能自己解决很棒棒!

    问代码相关的问题,建议将相关的代码贴出来。这样会对解决问题有很大帮助。