java中数组的定义及使用方法(推荐)

 更新时间:2016年07月24日 13:04:02   投稿:jingxian  
下面小编就为大家带来一篇java中数组的定义及使用方法(推荐)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧

数组:是一组相关变量的集合

数组是一组相关数据的集合,一个数组实际上就是一连串的变量,数组按照使用可以分为一维数组、二维数组、多维数组

数据的有点

不使用数组定义100个整形变量:int i1;int i2;int i3

使用数组定义 int i[100];

数组定义:int i[100];只是一个伪代码,只是表示含义的

一维数组

一维数组可以存放上千万个数据,并且这些数据的类型是完全相同的,

使用java数组,必须经过两个步骤,声明数组和分配内存给该数组,

声明形式一

声明一维数组:数据类型 数组名[]=null;

非配内存给数组:数组名=new 数据类型[长度];

声明形式二

声明一维数组:数据类型 [] 数组名=null;

java数据类型分为两大类

基本数据类型

int、long操作的时候本身就是具体的内容

引用数据类型:数组、类、接口

引用传递的就是一个内存的使用权,一块内存空间,可能有多个人同时使用

事例声明数组

package com.qn.array;

public class Test {
  public static void main(String[] args) {
 int score[]=null;//声明数组
 score=new int[3];//开辟空间,大小为3
 }
}

数组的声明格式里,数据类型是数组元素的数据类型,常见的有整形、浮点型、与字符型等

数组名是用来统一这组相同数据类型元素的名称,其命名规则和变量的相同

数组声明后实际上是在栈内存中保存了此数组的名称,结下了是要在堆内存中配置数组所需要的内存,齐产固定是告诉编译器,所声明的数组要存放多少个元素,而new 则是命令编译器根据括号里的长度

基本数据类型偶读有其默认值:int 0;只要是引用数据类型默认值就是null

事例

package com.qn.array;

public class Test {
  public static void main(String[] args) {
 int score[]=null;//声明数组
 score=new int[3];//开辟空间,大小为3
 System.out.print("score[0]="+score[0]);
 System.out.print("\tscore[1]="+score[1]);
 System.out.print("\tscore[2]="+score[2]);
 }
}

堆栈内存的解释

数组操作中,在栈内存中保存的永远是数组的名称,只开辟了栈内的空间,数组是永远无法使用的,必须有指向的对内存才可以使用,要想开辟新对内存空间必须使用new关键字,之后就是将对内存的使用权交给对应的栈内存,而且一个堆内存空间可以同时被多个栈内存空间指向,比如一个人可以有多个名字,人就相当于对内存,名字就相当于栈内存

声明数组的同时分配内存空间

声明数组的同时非配内存

数据类型 数组名[]=new 数据类型[个数]

int score[]=new int[10];

声明一个元素个数为10的整形数组score,同时开辟依靠内存空间工期使用

java中,由于整形数据类型占用的空间为4个byte,而整个数组score可保存的元素有10个。所以上例中占用的内存共有4*10=40个字节

数组的访问

数组中元素的表示方法

想要访问数组里的元素可以利用索引来完成,java的数组索引标号由10开始,以一个score[10]的整形数组为例,score[0]代表第一个元素

一直向下,最后一个为score[9]

取得数组的长度

在java中取得数组的长度(也就是数组元素的长度)可以利用数组名称.length完成,

数组名称.length--返回一个int类型的数据

package com.qn.array;

public class Test {
  public static void main(String[] args) {
 int score[]=null;//声明数组
 score=new int[3];//开辟空间,大小为3
 System.out.println(score.length);
 }
}

结果

数组的静态初始化

之前的数组,所采用的都是动态初始化,所有的内容在数组声明的时候并不具体的指定,而是以默认值的形式出现

静态初始化是指在数组声明后直接为数组指定具体的内容

如果想要直接在声明的时候给数组赋初始值,可以采用大括号完成,只要在数组的生命格式后面加上初值的赋值即可,

数据类型 数组名 []={初始值0,初始值1,初始值3,....初始值n};

package com.qn.array;

public class Test {
  public static void main(String[] args) {
 int score[]={1,2,3,4,5,6};//使用静态初始化声明数组
 System.out.println(score.length);
 }
}

结果

6

范例求出数组中的最大值和最小值

package com.qn.array;

public class Test {
  public static void main(String[] args) {
 int score[]={45,12,8,23,89,56};//使用静态初始化声明数组
 int max=0;
 int min=0;
 max=min=score[0];
 for (int i = 0; i < score.length; i++) {
  if(score[i]>max){
  max=score[i];
  }
  if(score[i]
  min=score[i];
  }
  
 }
 
 System.out.println("最大值:"+max);
 System.out.println("最小值:"+min);
 }
}

结果

范例排序,在操作中排序是比较常用的

从大到小

package com.qn.array;

public class Test {
  public static void main(String[] args) {
 int score[]={45,12,8,23,89,56};//使用静态初始化声明数组
 int temp=0;
 for (int i = 0; i < score.length; i++) {
 for (int j = 0; j < score.length-1; j++) {
  if(score[i]>score[j]){
  temp=score[i];
  score[i]=score[j];
  score[j]=temp;
  
  }
  
 }
 }
 for (int i = 0; i < score.length; i++) {
  System.out.print(score[i]+"\t");
 }
  }
}

结果

这个时候不要被i值所迷惑   if(score[i]>score[j]){

这一步主要知识为了比较,实际上完成之后输出的时候是根据j的值排序的

二维数组

如果可以把一维数组当做几何中的一条线图形,那么二维数组就相当于一个表格

    A    B
1  姓名 年龄
2  齐宁  21
3  齐燕  23
4  齐威  26

二维数组声明的方式和以为数组的类似,内存分配也一样是用new这个关键字

其实声明与分配内存的格式如下

动态初始化

数据类型 数组名[][];

数组名=new 数据类型[行的个数][列的个数];

声明并初始化数组

数据类型 数组名[][]=new 数据类型[行的个数][列的个数];

静态初始化

二维数组的存储

声明二维数组score 同时开辟一段内存空间

int score[][]=new int[4][3];

整体数据score可保存的元素是4*3=12个,在java中,int数据类型所占用的空间为4个字节,因此该整形数组占用的内存共为4*12=48个字节

事例

package com.qn.array;

public class test1 {
 public static void main(String[] args) {
 int score[][] = new int[4][3];
 score[0][1] = 30;
 score[1][0] = 31;
 score[2][1] = 32;
 score[2][2] = 33;
 score[3][1] = 34;
 score[1][1] = 35;
 for (int i = 0; i < score.length; i++) {
  for (int j = 0; j < score[i].length; j++) {
  System.out.print(score[i][j]+"\t");
  }
  System.out.println("");
 }
 }
}

结果

二维数组静态初始化

用到的时候才会开辟空间,不用的(红色部分)则不开辟空间

多维数组

一般只是用到二维数组

三维数组简单了解

package com.qn.array;

public class test1 {
 public static void main(String[] args) {
 int score[][][]={
  {
   {5,1},{6,7}
  },
  {
   {9,4},{8,3}
  }
 };
 System.out.print(score[0][0][0]+"\t");
 System.out.print(score[0][0][1]+"\t");
 System.out.print(score[0][0][0]+"\t");
 System.out.print(score[0][0][1]+"\t");
 
 System.out.print(score[1][0][0]+"\t");
 System.out.print(score[1][0][1]+"\t");
 System.out.print(score[1][1][0]+"\t");
 System.out.print(score[1][1][1]+"\t");
 }
}

以上这篇java中数组的定义及使用方法(推荐)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 深入剖析java中的集合框架

    深入剖析java中的集合框架

    下面小编就为大家带来一篇深入剖析java中的集合框架。小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-05-05
  • 解决springboot启动成功,但访问404的问题

    解决springboot启动成功,但访问404的问题

    这篇文章主要介绍了解决springboot启动成功,但访问404的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-07-07
  • Java深度优先遍历解决排列组合问题详解

    Java深度优先遍历解决排列组合问题详解

    这篇文章主要介绍了Java深度优先遍历解决排列组合问题详解,深度优先搜索是递归过程,带有回退操作,因此需要使用栈存储访问的路径信息,当访问到的当前顶点没有可以前进的邻接顶点时,需要进行出栈操作,将当前位置回退至出栈元素位置,需要的朋友可以参考下
    2024-01-01
  • Java实现简单图书借阅系统

    Java实现简单图书借阅系统

    这篇文章主要为大家详细介绍了Java实现简单图书借阅系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • JavaSE系列基础包装类及日历类详解

    JavaSE系列基础包装类及日历类详解

    这篇文章主要介绍的是JavaSE中常用的基础包装类以及日历类的使用详解,文中的示例代码简洁易懂,对我们学习JavaSE有一定的帮助,感兴趣的小伙伴快来跟随小编一起学习吧
    2021-12-12
  • 解决spring jpa中update的坑

    解决spring jpa中update的坑

    这篇文章主要介绍了spring jpa中update遇到的坑及解决方法,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-08-08
  • Spark集群框架的搭建与入门

    Spark集群框架的搭建与入门

    Spark是专为大规模数据处理而设计的,基于内存快速通用,可扩展的集群计算引擎,实现了高效的DAG执行引擎,可以通过基于内存来高效处理数据流,运算速度相比于MapReduce得到了显著的提高。
    2021-06-06
  • 关于@SpringBootApplication详解

    关于@SpringBootApplication详解

    这篇文章主要介绍了关于@SpringBootApplication的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-08-08
  • Java基础之详解基本数据类型的使用

    Java基础之详解基本数据类型的使用

    今天给大家带来的是关于Java基础的相关知识,文章围绕着基本数据类型的使用展开,文中有非常详细的介绍及代码示例,需要的朋友可以参考下
    2021-06-06
  • 关于SpringSecurity的基本使用示例

    关于SpringSecurity的基本使用示例

    这篇文章主要介绍了关于SpringSecurity的基本使用示例,SpringSecurity 本质是一个过滤器链SpringSecurity 采用的是责任链的设计模式,它有一条很长的过滤器链,需要的朋友可以参考下
    2023-05-05

最新评论