Java 基础——Scanner 类详解,零基础小白到精通,收藏这篇就够了

一、Scanner 类概述

Scanner 类是 Java 中用于获取用户输入的一个实用类,它位于 java.util 包下。

通过 Scanner 类,可以方便地从多种输入源(比如标准输入流,也就是键盘输入,或者文件等)读取不同类型的数据,例如整数、小数、字符串等,大大简化了输入操作相关的编程工作。

二、Scanner 类的创建

在使用 Scanner 类之前,需要先创建它的对象。如果要从标准输入(键盘)读取数据,创建示例代码如下:

import java.util.Scanner;

public class ScannerExample {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        // 后续可使用该scanner对象进行输入读取操作
    }
}

这里通过 new Scanner(System.in) 创建了一个 Scanner 对象,System.in 表示标准输入流,意味着后续操作将从键盘获取输入内容。

三、常用方法及读取不同类型数据

1.读取整数
使用 nextInt() 方法可以读取用户输入的整数,示例代码如下:

import java.util.Scanner;

public class ReadInt {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        System.out.println("请输入一个整数:");
        int num = scanner.nextInt();//程序执行到这里就会停下来,等待键盘的输入。
                                    //键盘如果没有输入,这里就会一直卡着
            //直到用户输入了内容之后,敲回车,这行代码就执行结束了
             //这样就完成了数据从控制台到内存

        System.out.println("你输入的整数是: " + num);
        scanner.close();
    }
}

这里提示用户输入整数后,调用 nextInt() 方法获取输入并赋值给 int 类型的变量 num,最后输出展示读取到的整数内容。需要注意的是,在读取完成后,如果不再需要使用该 Scanner 对象,最好调用 scanner.close() 方法关闭它,以释放相关资源。

注意:针对nextInt()方法来说,只能接收整数数字。输入其他的字符串会报错。

2.读取浮点数(小数)
若要读取浮点数,可以使用 nextFloat() 方法(读取单精度浮点数) 或者 nextDouble() 方法(读取双精度浮点数),示例代码如下:

import java.util.Scanner;

public class ReadFloat {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        System.out.println("请输入一个单精度浮点数:");
        float fNum = scanner.nextFloat();
        System.out.println("你输入的单精度浮点数是: " + fNum);

        System.out.println("请输入一个双精度浮点数:");
        double dNum = scanner.nextDouble();
        System.out.println("你输入的双精度浮点数是: " + dNum);

        scanner.close();
    }
}

上述代码分别演示了读取单精度和双精度浮点数的过程,按照提示输入相应类型的小数,就能通过对应方法获取并输出展示。

3.读取字符串

读取字符串有两种常用方式,一种是 next() 方法,一种是 nextLine() 方法。

(1).next() 方法: 它读取输入的下一个单词(以空格、制表符等空白字符作为分隔符)

细节:从键盘上接收一个字符串,但是接收的是第一个空格之前的内容

示例代码1:

import java.util.Scanner;

public class ReadStringNext {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        System.out.println("请输入一些单词(以空格分隔):");
        String word = scanner.next();
        System.out.println("你输入的单词是: " + word);
        scanner.close();
    }
}

输入多个单词时,它只会获取第一个单词并返回。

示例代码2:

import java.util.Scanner;
public class scannerTest {
    public static void main(String[] args) {
        Scanner s=new Scanner(System.in);
        String username=s.next();
        System.out.println(username);
    }
}

(2).nextLine() 方法:
该方法读取输入的一整行内容,示例代码:

import java.util.Scanner;

public class ReadStringNextLine {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        System.out.println("请输入一行文字:");
        String line = scanner.nextLine();
        System.out.println("你输入的文字内容是: " + line);
        scanner.close();
    }
}

它会获取从当前位置到行尾的所有字符,更适合读取完整的语句等情况。

注意:从键盘上接收一个字符串,但是接收的是第一个换行符\n之前的内容

可能遇到的问题及注意事项

1.输入不匹配异常

如果用户输入的数据类型和期望读取的数据类型不一致,例如:期望读取整数,但用户输入了字母等非数字内容,会抛出 InputMismatchException 异常。所以在实际应用中,可能需要添加异常处理代码来让程序更健壮,示例如下:

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

public class ExceptionHandle {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        try {
            System.out.println("请输入一个整数:");
            int num = scanner.nextInt();
            System.out.println("你输入的整数是: " + num);
        } catch (InputMismatchException e) {
            System.out.println("输入的数据类型不正确,请重新输入整数!");
        } finally {
            scanner.close();
        }
    }
}

这里使用 try-catch 语句块捕获可能出现的输入类型不匹配异常,并在 catch 块中给出相应提示,无论是否出现异常,最终都会在 finally 块中关闭 Scanner 对象。

2.nextLine() 方法使用的坑

由于nextInt()只读取整数,不读取后续的换行符,这会导致nextLine()在下一次调用时直接读取空字符串。解决方法是使用nextLine()获取整数后的换行符,避免空字符导致的跳过输入现象。

import java.util.Scanner;
public class scannerTest {
    public static void main(String[] args) {
        Scanner s=new Scanner(System.in);
        String username=s.next(); //无论是next(),还是nextInt(),nextDouble()这几个方法接收的是第一个空格之前的内容
                         //而对于 son依旧留在缓存中,其在缓存的格式为 son\r(回车符)
        System.out.println(username);

        String position=s.nextLine();//执行到这一行时,nextLine回去缓存读内容,而读到\r时就结束了
                                     //即读取了 son
                                     //所以这一行的运行,用户无法输入东西
        System.out.println(position);

        String name =s.nextLine();
        System.out.println(name);
    }
}

运行结果:

当在调用 nextInt() 或者其他读取基本类型的方法(如 nextFloat() 等)后紧接着调用 nextLine() 方法时,可能会出现问题。因为 nextInt() 等方法读取数据后,留下的换行符(回车键对应的字符)会被 nextLine() 当作输入内容读取,导致 nextLine() 似乎 “跳过” 了用户的输入。解决办法通常是在调用 nextLine() 之前,先额外调用一次 nextLine() 来消耗掉前面留下的换行符,示例如下:

import java.util.Scanner;

public class NextLineIssue {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        System.out.println("请输入一个整数:");
        int num = scanner.nextInt();
        scanner.nextLine(); // 消耗掉换行符

        System.out.println("请输入一行文字:");
        String line = scanner.nextLine();
        System.out.println("你输入的文字内容是: " + line);

        scanner.close();
    }
}

总之,Scanner 类在 Java 中是很常用的用于处理输入的类,掌握好它的使用方法以及注意相关问题,能更好地实现具有交互性的 Java 程序。

Java程序员如今深陷技术迭代放缓与行业需求收缩的双重困境,职业发展空间正被新兴技术浪潮持续挤压。面对当前Java程序员可能面临的“发展瓶颈”或行业挑战,更积极的应对策略可以围绕技术升级、方向转型、能力拓展三个核心展开,而非被动接受“不行”的标签,通过调查对比,我发现人工智能大模型是个很好的出路。

技术升级与转型机会

  • 突破传统Java开发边界:大模型技术的普及为Java开发者提供了新的机遇,使他们能够突破传统企业级开发的局限,进入人工智能这一高增长领域。通过学习大模型集成,Java开发者可以转型为AI应用开发者,拓展职业发展空间。

  • 技术栈升级:Java社区积极拥抱大模型技术,推出了多个开源项目和框架,如Deeplearning4j、DJL(Deep Java Library)等。这些工具为Java开发者提供了丰富的资源,使他们能够更方便地构建和部署基于大模型的应用。

发挥Java在企业级应用中的优势

  • 稳定性与可靠性:Java作为企业级应用的主流语言,其稳定性和可靠性在大模型应用中同样得到体现。Java的强类型系统和严谨的工程化特性,在构建可靠的大模型应用时提供了额外保障。

  • 跨平台性:Java的“一次编写,到处运行”特性使其能够轻松部署到不同操作系统和硬件环境中。这一特性在大型模型的部署和集成中尤为重要,可以降低部署复杂性和成本。

  • 多线程处理能力:Java强大的多线程处理能力特别适合大模型的推理部署场景,可以高效处理并发请求,提升系统性能。

说真的,这两年看着身边一个个搞Java、C++、前端、数据、架构的开始卷大模型,挺唏嘘的。大家最开始都是写接口、搞Spring Boot、连数据库、配Redis,稳稳当当过日子。

结果GPT、DeepSeek火了之后,整条线上的人都开始有点慌了,大家都在想:“我是不是要学大模型,不然这饭碗还能保多久?”

先给出最直接的答案:一定要把现有的技术和大模型结合起来,而不是抛弃你们现有技术!掌握AI能力的Java工程师比纯Java岗要吃香的多。

即使现在裁员、降薪、团队解散的比比皆是……但后续的趋势一定是AI应用落地!大模型方向才是实现职业升级、提升薪资待遇的绝佳机遇!

如何学习AGI大模型?

作为一名热心肠的互联网老兵,我决定把宝贵的AI知识分享给大家。 至于能学习到多少就看你的学习毅力和能力了 。我已将重要的AI大模型资料包括AI大模型入门学习思维导图、精品AI大模型学习书籍手册、视频教程、实战学习等录播视频免费分享出来。

因篇幅有限,仅展示部分资料,需要点击下方链接即可前往获取

2025最新版优快云大礼包:《AGI大模型学习资源包》免费分享**

一、2025最新大模型学习路线

一个明确的学习路线可以帮助新人了解从哪里开始,按照什么顺序学习,以及需要掌握哪些知识点。大模型领域涉及的知识点非常广泛,没有明确的学习路线可能会导致新人感到迷茫,不知道应该专注于哪些内容。

我们把学习路线分成L1到L4四个阶段,一步步带你从入门到进阶,从理论到实战。

L1级别:AI大模型时代的华丽登场

L1阶段:我们会去了解大模型的基础知识,以及大模型在各个行业的应用和分析;学习理解大模型的核心原理,关键技术,以及大模型应用场景;通过理论原理结合多个项目实战,从提示工程基础到提示工程进阶,掌握Prompt提示工程。

L2级别:AI大模型RAG应用开发工程

L2阶段是我们的AI大模型RAG应用开发工程,我们会去学习RAG检索增强生成:包括Naive RAG、Advanced-RAG以及RAG性能评估,还有GraphRAG在内的多个RAG热门项目的分析。

L3级别:大模型Agent应用架构进阶实践

L3阶段:大模型Agent应用架构进阶实现,我们会去学习LangChain、 LIamaIndex框架,也会学习到AutoGPT、 MetaGPT等多Agent系统,打造我们自己的Agent智能体;同时还可以学习到包括Coze、Dify在内的可视化工具的使用。

L4级别:大模型微调与私有化部署

L4阶段:大模型的微调和私有化部署,我们会更加深入的探讨Transformer架构,学习大模型的微调技术,利用DeepSpeed、Lamam Factory等工具快速进行模型微调;并通过Ollama、vLLM等推理部署框架,实现模型的快速部署。

整个大模型学习路线L1主要是对大模型的理论基础、生态以及提示词他的一个学习掌握;而L3 L4更多的是通过项目实战来掌握大模型的应用开发,针对以上大模型的学习路线我们也整理了对应的学习视频教程,和配套的学习资料。

二、大模型经典PDF书籍

书籍和学习文档资料是学习大模型过程中必不可少的,我们精选了一系列深入探讨大模型技术的书籍和学习文档,它们由领域内的顶尖专家撰写,内容全面、深入、详尽,为你学习大模型提供坚实的理论基础(书籍含电子版PDF)

三、大模型视频教程

对于很多自学或者没有基础的同学来说,书籍这些纯文字类的学习教材会觉得比较晦涩难以理解,因此,我们提供了丰富的大模型视频教程,以动态、形象的方式展示技术概念,帮助你更快、更轻松地掌握核心知识

四、大模型项目实战

学以致用 ,当你的理论知识积累到一定程度,就需要通过项目实战,在实际操作中检验和巩固你所学到的知识,同时为你找工作和职业发展打下坚实的基础。

五、大模型面试题

面试不仅是技术的较量,更需要充分的准备。

在你已经掌握了大模型技术之后,就需要开始准备面试,我们将提供精心整理的大模型面试题库,涵盖当前面试中可能遇到的各种技术问题,让你在面试中游刃有余。


因篇幅有限,仅展示部分资料,需要点击下方链接即可前往获取

2025最新版优快云大礼包:《AGI大模型学习资源包》免费分享

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值