博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
java学习笔记04--数组
阅读量:6176 次
发布时间:2019-06-21

本文共 2072 字,大约阅读时间需要 6 分钟。

java学习笔记04--数组

 

数组复制的方法是使用System类提供的arraycopy()方法,其语法如下:

System.arraycopy(Object src, int srcPos, Object dest, int destPos, int length);

System.arraycopy(源数组,源数组中的起始位置,目标数组,目标数据中的起始位置,要复制的数组元素的数量);

[java]
  1. public class T {  
  2.     public static void main(String args[]){  
  3.         int arr1[] = {
    1,2,3,4,5};  
  4.         int arr2[] = new int[5];  
  5.         System.arraycopy(arr1, 0, arr2, 0, 5);  
  6.         for (int i = 0; i < arr2.length; i++) {  
  7.             System.out.println(arr2[i]);  
  8.         }  
  9.     }  
  10. }  

Arrays类

对数组的一些基本操作,像排序、搜索与比较等都是很常见的。在java中提供了Array是类可以协助您作这几个操作,Array是类位于java.util包中,他提供了几个方法可以直接使用。

sort()                       帮助您对指定的数组排序,所使用的是快速排序法

binarySearch()      让您对已排序的数组进行二元搜索,如果找到指定的值就返回该值所在的索引,否则就返回负值

fill()                           当您配置一个数组之后,会依据数据类型来给定默认值。例如整数数组就初始值为0,可以使用Arrays.fill()方法将所有的元素设置为指定的值

equals()                   比较两个数组中的元素值是否全部相等,如果是将返回true,否则返回false

[java]
  1. import java.util.Scanner;  
  2. import java.util.Arrays;  
  3.   
  4. public class T {  
  5.     public static void main(String[] args) {  
  6.         Scanner scanner = new Scanner(System.in);  
  7.   
  8.         int[] arr = { 93, 5, 3, 55, 57, 7, 2, 73, 41, 91 };  
  9.   
  10.         System.out.print("排序前: ");  
  11.         for (int i = 0; i < arr.length; i++){  
  12.             System.out.print(arr[i] + " ");  
  13.         }  
  14.         System.out.println();  
  15.   
  16.         Arrays.sort(arr);  
  17.   
  18.         System.out.print("排序后: ");  
  19.         for (int i = 0; i < arr.length; i++){  
  20.             System.out.print(arr[i] + " ");  
  21.         }  
  22.         System.out.print("\n请输入搜索值:");  
  23.         int key = scanner.nextInt();  
  24.         int find = -1;  
  25.         if ((find = Arrays.binarySearch(arr, key)) > -1) {  
  26.             System.out.println("找到值于索引 " + find + " 位置");  
  27.         } else  
  28.             System.out.println("找不到指定值");  
  29.     }  
  30. }  

执行结果:

[java]
  1. 排序前: 93 55 57 73 41 91   
  2. 排序后: 41 55 57 73 91 93   
  3. 请输入搜索值:5  
  4. 找到值于索引 2 位置  

下面使用Arrays来进行数组的填充与比较

[java]
  1. import java.util.Arrays;  
  2.   
  3. public class T {  
  4.     public static void main(String[] args) {  
  5.         int[] arr1 = new int[10];  
  6.         int[] arr2 = new int[10];  
  7.         int[] arr3 = new int[10];  
  8.   
  9.         Arrays.fill(arr1, 5);  
  10.         Arrays.fill(arr2, 5);  
  11.         Arrays.fill(arr3, 10);  
  12.   
  13.         System.out.print("arr1: ");  
  14.         for (int i = 0; i < arr1.length; i++){  
  15.             System.out.print(arr1[i] + " ");      
  16.         }  
  17.         System.out.println("\narr1 = arr2 ? " + Arrays.equals(arr1, arr2));  
  18.         System.out.println("arr1 = arr3 ? " + Arrays.equals(arr1, arr3));  
  19.     }  
  20. }  

执行结果

[java]
    1. arr1: 5   
    2. arr1 = arr2 ? true  
    3. arr1 = arr3 ? false 

转载地址:http://rvwda.baihongyu.com/

你可能感兴趣的文章
使用cnpm加速npm
查看>>
MySql跨服务器备份数据库
查看>>
一个字典通过dictionaryWithDictionary 他们的内存指针是不同的
查看>>
HTTP 错误 500.0的解决方法。
查看>>
CCF201612-1 中间数(解法三)(100分)
查看>>
百度前端任务一学习的知识
查看>>
C# 四个字节十六进制数和单精度浮点数之间的相互转化
查看>>
JavaNIO的总结
查看>>
阿里云总监课第五期PPT下载地址
查看>>
时间属性
查看>>
第十九章:集合视图(十七)
查看>>
BIOS
查看>>
Elasticsearch之元数据(meta-fields)介绍
查看>>
基于Django+Bootstrap框架,可视化展示内存监控信息
查看>>
Pytorch | BERT模型实现,提供转换脚本【横扫NLP】
查看>>
biostar handbook: 第七周笔记汇总+调整通知
查看>>
涨薪必备|给你一份超详细Spring Boot知识清单
查看>>
YII2 关联查询,不修改search, 使用 GridView::widget 输出
查看>>
DNS服务-了解篇
查看>>
Apache Shiro在web开发安全技术中的应用
查看>>