IO实战篇:数字大小比较 | 带你学《Java语言高级特性》之七十二

简介: 本节将带着读者开发实际案例,实现对输入的数字大小的比较功能,并求出所输数字的最大值和最小值。

上一篇:transient:将属性脱离序列化 | 带你学《Java语言高级特性》之七十一

本节将带着读者开发实际案例,实现对输入的数字大小的比较功能,并求出所输数字的最大值和最小值。

【本节目标】
通过阅读本节内容,你将复习Scanner的相关知识,结合工厂模式,编写数字处理相关接口并完成实现,最终实现求出输入的三个数字的最大值和最小值的功能。

数字大小比较

编写java程序,输入3个整数,并求出3个整数的最大值和最小值。

如果要想进行数字的输入处理,那么应该保证输入错误的时候可以重新输入,那么为了可以达到重用的设计,应该准备一个单独的输入数据类。

1、 定义一个输入工具类

public class InputUtil {
    private InputUtil(){}
    /**
     * 实现键盘接收数字的操作
     * @param prompt 提示信息
     * @return 一个可以使用的数字
     */
    public static int getInt(String prompt){
        int num = 0;
        boolean flag = true; 
        while (flag){
            Scanner input = new Scanner(System.in);
            System.out.print(prompt);  //打印提示信息
            if(input.hasNext("\\d+")){
                num = Integer.parseInt(input.next("\\d+"));  
                flag = false ;
            }else{
                System.out.println("输入的内容不是数字!");
            }
        }
        return num ;
    }
}

或者使用BufferedReader 来定义。

public class InputUtil {
    private InputUtil(){}
    /**
     * 实现键盘接收数字的操作
     * @param prompt 提示信息
     * @return 一个可以使用的数字
     */
    public static int getInt(String prompt){
        BufferedReader buf = new BufferedReader(new InputStreamReader(System.in));
        int num = 0;
        boolean flag = true; 
        while (flag){
            System.out.print(prompt);  //打印提示信息
            String str = null;
            try{
                str = buf.readLine();
                if(str.matches("\\d+")){
                     num = Integer.parseInt(str);  
                     flag = false ;
                }else{
                     System.out.println("输入的内容不是数字!");
                }
            }catch(IOException e) {
                System.out.println("输入的内容不是数字!");
            }
        }
        return num ;
    }
}

2、 定义数据的输入处理

public interface INumberService{
    /**
     * 输入数据并返回输入数据的最大值和最小值
     * @param count 表示要输入数据的个数
     * @return  包含有两个内容:第一个是最大值,第二个是最小值
     */
    public int[] stat(int count);
}

3、 定义接口的实现子类

public class NumberServiceImpl implements INumberService{
    @Override
    public int[] stat(int count) {
        int result[] = new int[2];   //定义返回的结果
        int data[] = new int[count];    //开辟一个数组
        for (int x = 0; x < data.length; x++) {   //数字的循环输入
            data[x]=InputUtil.getInt("请输入第""+(x+1)+""个数字:");
        }
        result[0]=data[0];   //最大值
        result[1]=data[0];   //最小值
        for(int x = 0 ;x < data.length; x ++) {
           if(data[x] > result[0]) {
               result[0] = data[x];
           }
           if(data[x] < result[1]) {
               result[1] = data[x];
           }
        }
        return result;
    }
}

4、 定义工厂类获取接口对象

public class Factory{
    private Factory(){}
    public static INumberService getInstance(){
        return new NumberServiceImpl();
    }
}  

5、 编写测试程序类

public class IOCaseDemo{
    public static void main(String[] args) {
        INumberService numberService = Factory.getInstance();
        int result [] = numberService.stat(5);
        System.out.println("最大值:"+ result[0]+ "、最小值:"+ result[1] );
    }
}

image.png
执行结果

想学习更多的Java的课程吗?从小白到大神,从入门到精通,更多精彩不容错过!免费为您提供更多的学习资源。
本内容视频来源于阿里云大学

下一篇:IO实战篇:文件保存 | 带你学《Java语言高级特性》之七十三
更多Java面向对象编程文章查看此处

相关文章
|
28天前
|
存储 人工智能 算法
数据结构与算法细节篇之最短路径问题:Dijkstra和Floyd算法详细描述,java语言实现。
这篇文章详细介绍了Dijkstra和Floyd算法,这两种算法分别用于解决单源和多源最短路径问题,并且提供了Java语言的实现代码。
63 3
数据结构与算法细节篇之最短路径问题:Dijkstra和Floyd算法详细描述,java语言实现。
|
20天前
|
存储 安全 Java
Java Map新玩法:探索HashMap和TreeMap的高级特性,让你的代码更强大!
【10月更文挑战第17天】Java Map新玩法:探索HashMap和TreeMap的高级特性,让你的代码更强大!
47 2
|
20天前
|
存储 Java 开发者
Java Map实战:用HashMap和TreeMap轻松解决复杂数据结构问题!
【10月更文挑战第17天】本文深入探讨了Java中HashMap和TreeMap两种Map类型的特性和应用场景。HashMap基于哈希表实现,支持高效的数据操作且允许键值为null;TreeMap基于红黑树实现,支持自然排序或自定义排序,确保元素有序。文章通过具体示例展示了两者的实战应用,帮助开发者根据实际需求选择合适的数据结构,提高开发效率。
50 2
|
3天前
|
SQL 安全 Java
安全问题已经成为软件开发中不可忽视的重要议题。对于使用Java语言开发的应用程序来说,安全性更是至关重要
在当今网络环境下,Java应用的安全性至关重要。本文深入探讨了Java安全编程的最佳实践,包括代码审查、输入验证、输出编码、访问控制和加密技术等,帮助开发者构建安全可靠的应用。通过掌握相关技术和工具,开发者可以有效防范安全威胁,确保应用的安全性。
14 4
|
25天前
|
存储 消息中间件 安全
JUC组件实战:实现RRPC(Java与硬件通过MQTT的同步通信)
【10月更文挑战第9天】本文介绍了如何利用JUC组件实现Java服务与硬件通过MQTT的同步通信(RRPC)。通过模拟MQTT通信流程,使用`LinkedBlockingQueue`作为消息队列,详细讲解了消息发送、接收及响应的同步处理机制,包括任务超时处理和内存泄漏的预防措施。文中还提供了具体的类设计和方法实现,帮助理解同步通信的内部工作原理。
JUC组件实战:实现RRPC(Java与硬件通过MQTT的同步通信)
|
30天前
|
存储 缓存 Java
java基础:IO流 理论与代码示例(详解、idea设置统一utf-8编码问题)
这篇文章详细介绍了Java中的IO流,包括字符与字节的概念、编码格式、File类的使用、IO流的分类和原理,以及通过代码示例展示了各种流的应用,如节点流、处理流、缓存流、转换流、对象流和随机访问文件流。同时,还探讨了IDEA中设置项目编码格式的方法,以及如何处理序列化和反序列化问题。
65 1
java基础:IO流 理论与代码示例(详解、idea设置统一utf-8编码问题)
|
11天前
|
网络协议 物联网 API
Python网络编程:Twisted框架的异步IO处理与实战
【10月更文挑战第26天】Python 是一门功能强大且易于学习的编程语言,Twisted 框架以其事件驱动和异步IO处理能力,在网络编程领域独树一帜。本文深入探讨 Twisted 的异步IO机制,并通过实战示例展示其强大功能。示例包括创建简单HTTP服务器,展示如何高效处理大量并发连接。
33 1
|
18天前
|
存储 Java API
优雅地使用Java Map,通过掌握其高级特性和技巧,让代码更简洁。
【10月更文挑战第19天】本文介绍了如何优雅地使用Java Map,通过掌握其高级特性和技巧,让代码更简洁。内容包括Map的初始化、使用Stream API处理Map、利用merge方法、使用ComputeIfAbsent和ComputeIfPresent,以及Map的默认方法。这些技巧不仅提高了代码的可读性和维护性,还提升了开发效率。
39 3
|
18天前
|
存储 安全 Java
Java Map新玩法:深入探讨HashMap和TreeMap的高级特性
【10月更文挑战第19天】Java Map新玩法:深入探讨HashMap和TreeMap的高级特性,包括初始容量与加载因子的优化、高效的遍历方法、线程安全性处理以及TreeMap的自然排序、自定义排序、范围查询等功能,助你提升代码性能与灵活性。
23 2
|
22天前
|
开发框架 Java 程序员
揭开Java反射的神秘面纱:从原理到实战应用!
本文介绍了Java反射的基本概念、原理及应用场景。反射允许程序在运行时动态获取类的信息并操作其属性和方法,广泛应用于开发框架、动态代理和自定义注解等领域。通过反射,可以实现更灵活的代码设计,但也需注意其性能开销。
41 1
下一篇
无影云桌面