热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

不会用的Java数组,从青铜到王者,全解析数组,建议收藏!!!

点赞再看,养成习惯目录1、数组的定义2、array遍历3、List和array之间的转换4、可能遇到的问题常规福利1、数组的定义先声明后使用数据类型[]数组名称new数据类型[长度

图片



点赞再看,养成习惯


目录

1、数组的定义

2、array 遍历

3、List和array 之间的转换

4、可能遇到的问题

常规福利




1、数组的定义


  • 先声明后使用

数据类型 [] 数组名称 = new 数据类型[长度];String[] arr3 = new String[5];

数据类型 数组名称[] = new 数据类型[长度];String  arr[] = new String[5];


  • 直接初始化

String[]  arrs = {"1","2","3"};


  • 声明并初始化

    String[] sarr = new String[]{"a","b"};


2、array 遍历


  • 流遍历

    将数组封装成流进行操作,所有的操作都和列表一样操作

public static void main(String[] args) {
      String[] arrs = {"1","2","3"};
      Arrays.stream(arrs).forEach(System.out::println);
  }

  • 普通遍历

    普通遍历有三种方式,建议使用第一种,

    如果需要使用索引可以使用第三种

    如果想要倒序,则使用第三种图片


3、List和array 之间的转换

list 和 array 之间大有联系,list 的实现形式有链表和 数组,我们开发中经常需要对两者进行转换

1、数组转list


  • 使用循环 转换为list

  • 借助工具方法

    代码展示:

       public static void main(String[] args) {
           String[]  arrs = {"1","2","3"};
           // 循环转换
           List list1 = new ArrayList<>();
           for (String arr : arrs) {
               list1.add(arr);
          }
           // 借助数组工具类
           List list2 = Arrays.asList(arrs);
           // 借助集合工具类
           List list3 = new ArrayList<>();
           Collections.addAll(list2,arrs);
      }

2、list 转数组


  • list 内置方法 toArray

  • 直接循环

    代码展示

   public static void main(String[] args) {
       List list = Arrays.asList("1","2");
       String[] arr1 = new String[list.size()];
       // 循环遍历赋值
       for (int i = 0; i < list.size(); i++) {
           arr1[i] = list.get(i);
      }
       // 调用list 方法
       String[] arr2 = (String[]) list.toArray();
  }

4、Arrays工具类


  • toString()


打印数组的方法,如果不调用这个方法打印的是内存地址


图片


  • stream()


将数组转换为流操作,具体就不演示了



  • sort()


    对数组进行排序,注意这个排序是数组内部排序,没有返回值,原数组会被改变


  • setAll


    对数组内的元素进行操作,需要提供一个function,具有不同的数据类型


String[] arrs = {"1","2","3"};
      Arrays.setAll(arrs, e->e+"0");
      for (String arr : arrs) {
          System.out.println(arr);
      }

  • binarySearch


    看名字都知道这是二分查找,具体的算法也很简单,如果你还不会,可以补一下了,如果你懂二分查找应该知道,在调用这个方法之前要保证数组是有序的!


  • copyOf


    名字也很直白,拷贝数组,扩展就是增加一些长度限制,或者填充数据的设置


  • equals


    看起来不需要解释


  • deepEquals


    判断两个数组的深度是否相同,也就是数组嵌套了几层


public static void main(String[] args) {
      String[] arrs = {"1","2","3"};
      String[][] arr2 = {{"1"},{"2"},{"3"}};
      boolean b = Arrays.deepEquals(arr2, arrs);
      System.out.println(b);
  }

  • fill


    认识英语的话基本上都懂,就是如何填充数组,当然你也可以自己进行循环操作


  • hashCode


    计算数组的hash code


  • parallelPrefix


    这个有些意思的,并行的累计操作数组内的元素,看个例子你就知道了


    public static void main(String[] args) {
           String[]  sarr = new String[]{"a","b","c"};
           Arrays.parallelPrefix(sarr, (sum,e1)->e1 + sum);
           System.out.println(Arrays.toString(sarr));
      }

看下执行结果:

图片


4、可能遇到的问题

1、索引越界问题,数组的下标索引是从0 开始的,最后一个索引是length -1 ,注意不要越界

2、下面的方式创建的列表不支持添加

因为Arrays中的ArrayList并没有实现remove()和add()方法,所以抛出了异常。所以说 Arrays.asList 返回的 List 是一个不可变长度的列表,此列表不再具备原 List 的很多特性,因此慎用 Arrays.asList 方法。

String[] arr = {"1", "2", "3"};
       List list = Arrays.asList(arr);
       arr[1] = "4";
       try {
           list.add("5");
      } catch (Exception ex) {
           ex.printStackTrace();
      }

3、一个小技巧,将数组绕成圈进行遍历

使用对数组长度取余即可

   public static void main(String[] args) {
       String[] arr = {"a", "b", "c"};
       int i = 0;
       int j = 0;
       int length = arr.length;
       while (j++ <10){
           System.out.println(arr[i%length]);
           i++;
      }
  }

可以看到多次遍历了数组

图片


常规福利

图片



推荐阅读
  • 从 .NET 转 Java 的自学之路:IO 流基础篇
    本文详细介绍了 Java 中的 IO 流,包括字节流和字符流的基本概念及其操作方式。探讨了如何处理不同类型的文件数据,并结合编码机制确保字符数据的正确读写。同时,文中还涵盖了装饰设计模式的应用,以及多种常见的 IO 操作实例。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 2023年京东Android面试真题解析与经验分享
    本文由一位拥有6年Android开发经验的工程师撰写,详细解析了京东面试中常见的技术问题。涵盖引用传递、Handler机制、ListView优化、多线程控制及ANR处理等核心知识点。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 本文介绍了Java并发库中的阻塞队列(BlockingQueue)及其典型应用场景。通过具体实例,展示了如何利用LinkedBlockingQueue实现线程间高效、安全的数据传递,并结合线程池和原子类优化性能。 ... [详细]
  • Java 类成员初始化顺序与数组创建
    本文探讨了Java中类成员的初始化顺序、静态引入、可变参数以及finalize方法的应用。通过具体的代码示例,详细解释了这些概念及其在实际编程中的使用。 ... [详细]
  • 主要用了2个类来实现的,话不多说,直接看运行结果,然后在奉上源代码1.Index.javaimportjava.awt.Color;im ... [详细]
  • 本文详细介绍了Java中org.eclipse.ui.forms.widgets.ExpandableComposite类的addExpansionListener()方法,并提供了多个实际代码示例,帮助开发者更好地理解和使用该方法。这些示例来源于多个知名开源项目,具有很高的参考价值。 ... [详细]
  • Java内存管理与优化:自动与手动释放策略
    本文深入探讨了Java中的内存管理机制,包括自动垃圾回收和手动释放内存的方法。通过理解这些机制,开发者可以更好地优化程序性能并避免内存泄漏。 ... [详细]
  • 本文探讨了如何在编程中正确处理包含空数组的 JSON 对象,提供了详细的代码示例和解决方案。 ... [详细]
  • 本文介绍如何利用动态规划算法解决经典的0-1背包问题。通过具体实例和代码实现,详细解释了在给定容量的背包中选择若干物品以最大化总价值的过程。 ... [详细]
  • MQTT技术周报:硬件连接与协议解析
    本周开发笔记重点介绍了在新项目中使用MQTT协议进行硬件连接的技术细节,涵盖其特性、原理及实现步骤。 ... [详细]
  • 本文详细介绍了如何构建一个高效的UI管理系统,集中处理UI页面的打开、关闭、层级管理和页面跳转等问题。通过UIManager统一管理外部切换逻辑,实现功能逻辑分散化和代码复用,支持多人协作开发。 ... [详细]
  • 题目Link题目学习link1题目学习link2题目学习link3%%%受益匪浅!-----&# ... [详细]
author-avatar
yixianliu
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有