zoukankan      html  css  js  c++  java
  • Java入门(6)方法

    序言

    方法返回多个值

    使用集合类

    /**
         * 方法1:使用集合类 (Map以外的集合类也可以随意使用)
         * 目标:返回一个数组的最大值和最小值
         */
        public Map<String, Integer> test1(int[] arr) {
            Map<String, Integer> map = new HashMap<String, Integer>();
    
            int max = Integer.MIN_VALUE;
            int min = Integer.MAX_VALUE;
            for (int i = 0; i < arr.length; i++) {
                if (arr[i] > max) {
                    max = arr[i];
                }
                if (arr[i] < min) {
                    min = arr[i];
                }
            }
    
            map.put("max", max);
            map.put("min", min);
    
            return map;
        }
    View Code

    使用封装对象

    public class Result {
           private int max;
           private int min;
            // 构造函数
            public Result() {
                super();
            }
            public int getMax() {
                return max;
            }
            public void setMax(int max) {
                this.max = max;
            }
            public int getMin() {
                return min;
            }
            public void setMin(int min) {
                this.min = min;
            }
        }
    View Code

     

    /**
         * 方法2:使用封装对象
         * 目标:返回一个数组的最大值和最小值
         */
        public Result test2(int[] arr) {
            Result result = new Result();
    
            int max = Integer.MIN_VALUE;
            int min = Integer.MAX_VALUE;
            for (int i = 0; i < arr.length; i++) {
                if (arr[i] > max) {
                    max = arr[i];
                }
                if (arr[i] < min) {
                    min = arr[i];
                }
            }
    
            result.setMax(max);
            result.setMin(min);
    
            return result;
        }
    View Code

    使用引用传递

    /**
         * 方法3:使用引用传递 (不适用基本类型及其封装类和String类型)
         * 目标:返回数组长度,同时获取最大值和最小值
         */
        public int test3(int[] arr, Result result) {
            int max = Integer.MIN_VALUE;
            int min = Integer.MAX_VALUE;
    
            for (int i = 0; i < arr.length; i++) {
                if (arr[i] > max) {
                    max = arr[i];
                }
                if (arr[i] < min) {
                    min = arr[i];
                }
            }
    
            result.setMax(max);
            result.setMin(min);
    
            int total = arr.length;
            return total;
        }
    View Code

    测试

     /**
         * 测试main
         */
        public static void main(String[] args) {
            Test t = new Test();
    
            int[] arr = { 1, 2, 3, 4, 5, 6 };
            
            // ----------方法1测试-----------
            // Map<String, Integer> map = t.test1(arr);
            // System.out.println("max : " + map.get("max"));
            // System.out.println("min : " + map.get("min"));
    
            // ----------方法2测试-----------
            // Result result = t.test2(arr);
            // System.out.println("max : " + result.getMax());
            // System.out.println("min : " + result.getMin());
    
            // ----------方法3测试-----------
            Result result = new Result();
            int total = t.test3(arr, result);
            System.out.println("total : " + total);
            System.out.println("max : " + result.getMax());
            System.out.println("min : " + result.getMin());
        }
    }
    View Code

    形参个数可变

    public class Varargs
    {
        // 定义了形参个数可变的方法
        public static void test(int a , String... books)
        {
            // books被当成数组处理
            for (String tmp : books)
            {
                System.out.println(tmp);
            }
            // 输出整数变量a的值
            System.out.println(a);
        }
        public static void main(String[] args)
        {
            // 调用test方法
            test(5 , "疯狂Java讲义" , "轻量级Java EE企业应用实战");
        }
    }
    View Code

    资料

    java ref out

  • 相关阅读:
    算法导论读书笔记(未完成)
    工作心理学(未完成)
    面试疑难点解析
    aop难点解析。
    Mybatis框架解析之Builder解析
    HashMap原理总结
    编程基础的重要性(程序员之路)
    Java HashMap详解
    Java源码分析系列之HttpServletRequest源码分析
    JFinal源码 分析之 Core包分析
  • 原文地址:https://www.cnblogs.com/cnki/p/9290342.html
Copyright © 2011-2022 走看看