java数组的声明_Java数组定义常用方法[通俗易懂]

java数组的声明_Java数组定义常用方法[通俗易懂]Java数组定义常用方法Java中的数组、是一种简单的线性数据存储结构、他用牺牲自动扩展大小来换取与集合相比的唯一优势——查询效率的提升。Java中的数组有什么类型?我们要怎么定义这些数组呢?下面跟yjbys小编一起来学习Java数组定义常用方法吧!java中有两种数据类型:a)引用类型b)基础类型其中基础类型又有两种:b1)数值类型b2)及布尔类型。数组——也为java的一个数据类型、归类为引用…

大家好,又见面了,我是你们的朋友全栈君。

Java数组定义常用方法

Java中的数组、是一种简单的线性数据存储结构、他用牺牲自动扩展大小来换取与集合相比的唯一优势——查询效率的提升。Java中的数组有什么类型?我们要怎么定义这些数组呢?下面跟yjbys小编一起来学习Java数组定义常用方法吧!

java中有两种数据类型:

a)引用类型

b)基础类型

其中基础类型又有两种:

b1)数值类型

b2)及布尔类型。

数组——也为java的一个数据类型、归类为引用类型。本文意图说清楚两点:

1、数组的声明以及初始化。

2、常用的数组方法。

补充一点:对于我们常说的二维数组、多维数组其实是一维数组的`延伸、这里暂时只围绕一维数组。

【数组的声明及初始化】

1、数组的声明:

作为一种引用类型、就如我们平常使用引用类型的时候声明一样、一般有两种写法:

a) type[] arrayName; exp: String[] strArray;

b) type arrayName[]; exp: String strArray[];

第二种源于C的写法、由于很容易造成混淆、所以现在基本不使用这种声明方式了。

2、数组的初始化:

数组的初始化有两种:

a) 静态初始化——数组大小由系统分配、我们只为数组每个位置上赋值

String[] strArray1 = {“a”, “b”, “c”, “d”, “e”};

String[] strArray2 = new String[]{“a”, “b”, “c”, “d”, “e”};//在 new String[]中不能指定String数组的大小!

b)动态初始化——只指定数值的大小、初始化工作由系统为我们完成(即为数组的每个位置赋初始值)

String[] strArray3 = new String[5];//此时String数组的每个位置上的值都由系统来初始化、使用默认的值””

//我们能做的是动态的为strArray3每个位置上的值进行修改

for (int i = 0; i < strArray1.length; i++) {

//这里仅用原始的方法进行赋值。

strArray3[i] = strArray1[i];

}

【数组的常用方法】

package com.chy.array.usefulMethods;

import java.util.ArrayList;

import java.util.Arrays;

import java.util.Collections;

import java.util.HashSet;

import java.util.Set;

import com.chy.array.bean.Student;

@SuppressWarnings(“all”)

public class ArrayUseFulMethoed {

private static int[] intArray = {1, 2, 3, 4, 5};

private static String[] strArray = {“a”, “b”, “c”, “d”, “e”};

/**

* 填充元素、比较大小、复制元素

*/

public static void testFillArray(){

//注意字符串和对象的不同

Student[] student1 = new Student[4];

Student[] student2 = new Student[4];

System.out.println(Arrays.equals(student1, student2));//true

Arrays.fill(student1, 0, 4, new Student(1,”chy”));

Arrays.fill(student2, new Student(1,”chy”));

System.out.println(Arrays.equals(student1, student2));//false

String[] str1 = new String[4];

String[] str2 = new String[]{“a”, “a”, “a”, “a”};

String[] str3 = {new String(“a”), new String(“a”), new String(“a”), new String(“a”)};

Arrays.fill(str1, “a”);

System.out.println(Arrays.equals(str1, str2));//true

System.out.println(Arrays.equals(str2, str3));//true

String[] str4 = Arrays.copyOf(str1, 2);//是将传入的数组拷贝len个元素到新的数组、相当于复制本身的一部分或者全部形成一个全新的数组

System.out.println(str4.length + “=======” + Arrays.toString(str4));// 2=======[a, a]

String[] str5 = new String[8];

System.arraycopy(str4, 0, str5, 6, 2);//是将str4从下标0开的2个元素拷贝到从下标6开始放置的数组str5中

System.out.println(str5.length + “=======” + Arrays.toString(str5));// 8=======[null, null, null, null, null, null, a, a]

}

/**

* 以字符串的形式输出指定数组的“模样”

*/

public static void printOriginalArray(){

String intArrayToString = Arrays.toString(intArray);

System.out.println(intArrayToString); //result: [1, 2, 3, 4, 5]

}

/**

* 将数组转化成List集合

* 注意:不能直接将int[]转化为集合、因为asList()方法的参数必须是对象。应该先把int[]转化为Integer[]。

* 对于其他primitive类型的数组也是如此,必须先转换成相应的wrapper类型数组。

*/

public static void convetArrayToList(){

Integer[] integerArray = new Integer[intArray.length];

for (int i = 0; i < integerArray.length; i++) {

integerArray[i] = intArray[i];

}

ArrayList integerList1 = new ArrayList(Arrays.asList(integerArray));

/*

* 不能写成下面:

* ArrayList integerList2 = (ArrayList)Arrays.asList(integerArray);

* 返回的是List、强转可以通过编译、但是不能正常使用。

*/

for(int i : integerList1){

System.out.print(i);

}

//result: 12345

System.out.println();

}

/**

* 将List集合转换成数组

*/

public static void convetListToArray(){

ArrayList strList = new ArrayList(Arrays.asList(strArray));

String[] strArrayFromList = new String[strList.size()];

strList.toArray(strArrayFromList);

System.out.println(Arrays.toString(strArrayFromList)); //result: [a, b, c, d, e]

/*

* 注意:不能写成这样:String[] strArrayFromList = (String[])strList.toArray(strArrayFromList);会抛出ClassCastException。

* List.toArray()与List.toArray(T[] t)的区别在于:

* List.toArray()返回的是一个Object[]、不能强转成String[]、强转的话可以通过编译、但是不能进行String[]的操作

* 而List.toArray(T[] t)会将list的值转换成T类型的数组。

*/

}

/**

* 将数组转换成Set集合

*/

public static void convertArrayToSet(){

Set set = new HashSet(Arrays.asList(strArray));

//Set具有无序性、所以输出结构不一定是原来数组元素存放顺序

System.out.println(set); //result: [d, e, b, c, a]

}

/**

* 判断某个数组中是否包含一个元素、思路:将数组转换成list使用list的contains方法

*/

public static void isContainObject(){

ArrayList strList = new ArrayList(Arrays.asList(strArray));

System.out.println(strList.contains(“a”)); //result: true

//另一种实现

Arrays.sort(strArray);

if(Arrays.binarySearch(strArray, “c”) >= 0){

System.out.println(true);

}else{

System.out.println(false);

}

}

/**

* 将两个相同类型的数组连接起来

*/

public static void connTwoSameArray(){

int[] intArray2 = new int[]{6, 7, 8, 9, 10};

}

/**

* 将数组中数据排序

*/

public static void sortArray(){

String[] str = {“c”, “a” ,”d” ,”z” };

Arrays.sort(str);

System.out.println(Arrays.toString(str));

//反序、

Arrays.sort(str, Collections.reverseOrder());

System.out.println(Arrays.toString(str));

}

public static void main(String[] args) {

/*printOriginalArray();

convetArrayToList();

convetListToArray();

isContainObject();

convertArrayToSet();

sortArray();*/

testFillArray();

}

}

【Java数组定义常用方法】相关文章:

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/137136.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 计算距离矩阵的方法_矩阵的欧式距离

    计算距离矩阵的方法_矩阵的欧式距离给定一个 N 行 M 列的 01 矩阵 A,A[i][j] 与 A[k][l] 之间的曼哈顿距离定义为:dist(A[i][j],A[k][l])=|i−k|+|j−l|输出一个 N 行 M 列的整数矩阵 B,其中:B[i][j]=min1≤x≤N,1≤y≤M,A[x][y]=1dist(A[i][j],A[x][y])输入格式第一行两个整数 N,M。接下来一个 N 行 M 列的 01 矩阵,数字之间没有空格。输出格式一个 N 行 M 列的矩阵 B,相邻两个整数之间用一个空格隔开。数据范围

    2022年8月8日
    5
  • 深度图像基础知识(一)

    深度图像基础知识(一)深度图像(depthimage)也被称为距离影像(rangeimage),是指将从图像采集器到场景中各点的距离(深度)作为像素值的图像,它直接反映了景物可见表面的几何形状。深度图像经过坐标转换可以计算为点云数据,有规则及必要信息的点云数据也可以反算为深度图像数据。深度数据流所提供的图像帧中,每一个像素点代表的是在深度感应器的视野中,该特定的(x,y)坐标处物体到离摄像头平面最近的

    2022年4月25日
    37
  • 设计模式之工厂模式建议收藏

    一普通工厂模式1.类图2.代码实现#pragmaonce#include<iostream>usingnamespacestd;//抽象渲染类classIR

    2021年12月19日
    46
  • VRR的工作流程及G-sync和Freesync的区别

    VRR的工作流程及G-sync和Freesync的区别VRR的工作流程可以分为三个阶段,第一个阶段是帧率低于刷新率,第二个阶段是帧率接近刷新率,但是没有超过刷新率,第三个阶段是帧率超过刷新率。理想状态应该是第二个阶段,显卡的输出帧稳定,并且略小于显示器的刷新率,这样显示器有足够的时间去安排VBlank的时间,这时候垂直同步开与不开,几乎没有任何的区别,你的画面不可能发生撕裂。并且显卡是全程在不断的更新画面的,画面不存在滞后的现象,几乎不会产生延迟,这个便是理想状态的G-sync和Freesync,但是如果帧率高于显示器的刷新…

    2022年6月10日
    111
  • linux暴力破解工具

    对于Linux操作系统来说,一般通过VNC、Teamviewer和SSH等工具来进行远程管理,SSH是SecureShell的缩写,由IETF的网络小组(NetworkWorkingGroup)所制定;SSH 为建立在应用层基础上的安全协议。 SSH是目前较可靠,专为远程登录会话和其他网络服务提供安全性的协议。利用SSH协议可以有效防止远程管理过程中的信…

    2022年4月7日
    75
  • 求助,linux安装pycharm报错

    求助,linux安装pycharm报错错误如图,操作系统是银河麒麟v10sp1,下载的pycharm社区版2021.3.1.tar.gz,已安装jdk17!有没有没有知道的大神,告知一二!

    2022年8月31日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号