浅谈一下:Java当作数组的几个应用场景

简介: 浅谈一下:Java当作数组的几个应用场景

对于数组,在C语言中就有过学习,但是,并没有怎么进行总结过,所以,笔者在Java中,对数组的几个简单的应用场景进行总结一下:


1.保存数据

 

public static void main(String[] args) {
            int[] array = {1, 2, 3};
            for(int i = 0; i < array.length; ++i){
                System.out.println(array[i] + " ");
            }
        }

代码的运行结果为:


0a2653c851af460fa595bd959398a8f1.png


2.. 参数传基本数据类型

public static void main(String[] args) {
        int num = 0;
        func(num);
        System.out.println("num = " + num);
    }
    public static void func(int x) {
        x = 10;
        System.out.println("x = " + x);
    }

代码的运行结果为:


2d65d23f6d4748949b924e4057485923.png


发现在func方法中修改形参 x 的值, 不影响实参的 num 值.


3.. 参数传数组类型(引用数据类型)

 

public static void main(String[] args) {
        int[] arr = {1, 2, 3};
        func(arr);
        System.out.println("arr[0] = " + arr[0]);
    }
    public static void func(int[] a) {
        a[0] = 10;
        System.out.println("a[0] = " + a[0]);
    }

代码的运行结果为:


6de278e6d6694ce5bb08e7e842b7e74b.png


发现在func方法内部修改数组的内容, 方法外部的数组内容也发生改变. 因为数组是引用类型,按照引用类型来进行传递,是可以修改其中存放的内容的。


总结: 所谓的 "引用" 本质上只是存了一个地址. Java 将数组设定成引用类型, 这样的话后续进行数组参数传参, 其实 只是将数组的地址传入到函数形参中. 这样可以避免对整个数组的拷贝(数组可能比较长, 那么拷贝开销就会很大).


4. 作为函数的返回值

比如:获取斐波那契数列的前N项


public class Main {
    public static int[] fib(int n){
        if(n <= 0){
            return null;
        }
        int[] array = new int[n];
        array[0] = array[1] = 1;
        for(int i = 2; i < n; ++i){
            array[i] = array[i-1] + array[i-2];
        }
        return array;
    }
    public static void main(String[] args) {
        int[] array = fib(10);
        for (int i = 0; i < array.length; i++) {
            System.out.println(array[i]);
        }
    }
}


代码的运行结果为:


12c3b7f3f8814309a195c64f051d4445.png


拓展讲解:


1.作为函数的返回值部分:


 

public static void func1(int[] array) {
        array=new int[]{15,16,17};
    }
    public static  void func2(int[] array) {
        array[0]=99;
    }
    public static void main(String[] args) {
        int[] array1={1,2,3,4};    
        func1(array1);            //打印结果: [1,2,3,4]   
       // func2(array1);           //打印结果: [99,2,3,4]
    }


在上述代码中:对func1进行分析:


34e8d716411043c08c7ffba9fbba23de.png


形参的改变,不会影响实参!!


在上述代码中:func1仅仅是改变了形参的指向,并没有影响的实参!


对func2进行分析:


92ba0822ed0b46e1ae72df8a17d3a45b.png


在func2函数中,传递的是引用,我们可以通过引用来改变原来的值!!


总结一下:


当数组作为参数进行传递的时候,其实还是按值传递的,此时的值是一个地址!!那么就会出现两种情况:


情况1:形参修改指向,array=new int[10];  只会影响形参的指向!


比如:


 

public static void func1(int[] array) {
        array=new int[]{15,16,17};
    }
    public static void main(String[] args) {
        int[] array1={1,2,3,4};    
        func1(array1);            //打印结果: [1,2,3,4]   
    }

情况2:形参修改指向对象的值: array[0]=99,此时才会影响到实参!

public static  void func2(int[] array) {
        array[0]=99;
    }
    public static void main(String[] args) {
        int[] array1={1,2,3,4};
       // func2(array1);           //打印结果: [99,2,3,4]
    }

2.数组作为函数的返回值!


 

public  static int[] func10() {
        int[] tmpArr={11,22,33};
        return tmpArr;
    }
    public static void main(String[] args) {
        int[] array=func10();
        System.out.println(Arrays.toString(array));  //[11,22,33]
    }

上述代码的运行结果为:


d79b274929334152a6d38be91e2d1be3.png


画图分析为:


dfc80ca9d8004e6c9ddc00e8448ffc6a.png


解析:tmpArr 是在函数里面创建的局部变量!当遇见return 的时候,这个方法就结束了,那么tmpArr 就会被回收掉了(销毁),那么,就意味着,tmpArr把值传递给array后,就被回收了!!


3.方法内部接收数组,并且返回数组!


 

public static int[] grow(int[] array) {
        for (int i = 0; i < array.length; i++) {
            array[i]=array[i]*2;
        }
        return array;
    }
    public static void main(String[] args) {
        int[] array={1,2,3,4,5,6,7,8};
        int[] ret=grow(array);
        System.out.println(Arrays.toString(array));  //[2, 4, 6, 8, 10, 12, 14, 16]
        System.out.println(Arrays.toString(ret));    //[2, 4, 6, 8, 10, 12, 14, 16]
    }


上述代码的运行结果为:


0a2653c851af460fa595bd959398a8f1.png


画图解析一下:


2d65d23f6d4748949b924e4057485923.png


但是,另外一种写法: 我们需要简单思考一下哟!!


 

public static int[] grow(int[] array) {
        int[] tmpArray =new int[array.length];//java支持这种数组的创建!!里面可以是变量!
        for (int i = 0; i < array.length; i++) {
            tmpArray[i]=array[i]*2;
        }
        return tmpArray;
    }
    public static void main(String[] args) {
        int[] array={1,2,3,4,5,6,7,8};
        int[] ret=grow(array);
        System.out.println(Arrays.toString(array));  //[1, 2, 3, 4, 5, 6, 7, 8]
        System.out.println(Arrays.toString(ret));    //[2, 4, 6, 8, 10, 12, 14, 16]
    }

代码的运行结果为:


6de278e6d6694ce5bb08e7e842b7e74b.png


画图解析为:


12c3b7f3f8814309a195c64f051d4445.png

相关文章
|
4天前
|
监控 Java API
探索Java NIO:究竟在哪些领域能大显身手?揭秘原理、应用场景与官方示例代码
Java NIO(New IO)自Java SE 1.4引入,提供比传统IO更高效、灵活的操作,支持非阻塞IO和选择器特性,适用于高并发、高吞吐量场景。NIO的核心概念包括通道(Channel)、缓冲区(Buffer)和选择器(Selector),能实现多路复用和异步操作。其应用场景涵盖网络通信、文件操作、进程间通信及数据库操作等。NIO的优势在于提高并发性和性能,简化编程;但学习成本较高,且与传统IO存在不兼容性。尽管如此,NIO在构建高性能框架如Netty、Mina和Jetty中仍广泛应用。
19 3
|
2月前
|
存储 缓存 算法
Java 数组
【10月更文挑战第19天】Java 数组是一种非常实用的数据结构,它为我们提供了一种简单而有效的方式来存储和管理数据。通过合理地使用数组,我们能够提高程序的运行效率和代码的可读性。更加深入地了解和掌握 Java 数组的特性和应用,为我们的编程之旅增添更多的精彩。
36 4
|
2月前
|
存储 缓存 算法
提高 Java 数组性能的方法
【10月更文挑战第19天】深入探讨了提高 Java 数组性能的多种方法。通过合理运用这些策略,我们可以在处理数组时获得更好的性能表现,提升程序的运行效率。
43 2
|
2月前
|
存储 Java
Java“(array) <X> Not Initialized” (数组未初始化)错误解决
在Java中,遇到“(array) &lt;X&gt; Not Initialized”(数组未初始化)错误时,表示数组变量已被声明但尚未初始化。解决方法是在使用数组之前,通过指定数组的大小和类型来初始化数组,例如:`int[] arr = new int[5];` 或 `String[] strArr = new String[10];`。
99 2
|
2月前
|
存储 Java
什么是带有示例的 Java 中的交错数组?
什么是带有示例的 Java 中的交错数组?
56 9
|
2月前
|
Java
Java数组动态扩容和动态缩减
Java数组动态扩容和动态缩减
27 3
|
2月前
|
存储 算法 Java
Java一分钟之-数组的创建与遍历
数组作为Java中存储和操作一组相同类型数据的基本结构,其创建和遍历是编程基础中的基础。通过不同的创建方式,可以根据实际需求灵活地初始化数组。而选择合适的遍历方法,则可以提高代码的可读性和效率。掌握这些基本技能,对于深入学习Java乃至其他编程语言的数据结构和算法都是至关重要的。
33 6
|
2月前
|
存储 Java 程序员
【一步一步了解Java系列】:何为数组,何为引用类型
【一步一步了解Java系列】:何为数组,何为引用类型
34 1
|
2月前
|
存储 XML Java
如何在 Java 中将常见文档转换为 PNG 图像数组
如何在 Java 中将常见文档转换为 PNG 图像数组
20 1
|
2月前
|
存储 算法 Java
带你学习java的数组军队列
带你学习java的数组军队列
40 0