数组的静态初始化:

1.一维数组:

int [ ] arr = { 1,2,3,4 } ;

Object [ ] arr = {   new Object ( ) , new Object ( ) , new Object ( ) , new Object ( )  } ;

注意:声明数组时,当数组元素类型为引用数据类型时,数组中既可以储存此引用数据类型,也可以储存此引用数据类型对应的子类

eg: Object [ ]  arr ={     new 任意类   }   //由于 “ Object 类是祖宗类( java 中所有类的父类)“,所以 arr 数组中可以储存任意类型的对象,everyone !!!

2.二维数组;

int [ ] [ ] arr = {    { 1,3} , {  2,3,6 } , {   1  } ,{  2,3,6,7  }   } ;

Object [ ] [ ] arr ={

{  new Object ( ) , new Object ( ) } ,

{  new Object ( )  }   ,

{   new Object ( ) ,new Object ( ) ,new Object ( )   }

} ;  //二维数组这样写观感会更好一些,当然用一行代码也可以;

3.注意:静态初始化一定要在声明数组的同时初始化数组元素(数组的长度也会根据初始化时的元素个数而固定)

数组的动态初始化:

1.一维数组:

int [ ] arr = new int [ 打算为数组开辟 ?个 int 空间 ] ;

Object [ ] arr = new Object [ 4 ]   // 数组里 4 个 Object 空间,数组长度为 4  ,每个元素的初始值为 null ;

2.二维数组;

int [ ] [ ] arr = new int [ 二维数组里有几个一维数组 ] [ 每个一维数组里有几个元素 ] ;

Object [ ] [ ] arr = new Object [ 4 ] [ 5 ] ;  // arr 中有4个一维数组,每个一维数组的长度为5(有5个元素);

3.注意:动态初始化不能在声明数组的同时初始化数组元素,但在访问数组中元素前一定不要忘记重新赋值数组元素(虽然不重新赋值化元素也不会报错,但此时元素装的只是个垃圾值);

数组的遍历:

栗子是最好的老师:

 public class pra{
public static void main(String[] args) {
int [] arr1={1,2,3};
System.out.println("遍历一维数组arr1:");
printArray1(arr1);
int [] [] arr2={ {4,5,6},{7,8,9,10},{11}};
System.out.println("遍历二维数组arr2:");
printArray2(arr2);
}
//用来遍历 int 类型一维数组的静态方法
public static void printArray1(int [] array){
for(int i=0;i<array.length;i++){
System.out.println(array[i]);
}
}
//用来遍历 int 类型二维数组的静态方法
public static void printArray2(int [] [] array){
for(int i=0;i<array.length;i++){
for (int j=0;j<array[i].length;j++){
System.out.print(array[i][j]+"\t");
}
System.out.println();
}
}
} 运行结果:
--------------------------
遍历一维数组arr1:
1
2
3
遍历二维数组arr2:
4 5 6
7 8 9 10
11 Process finished with exit code 0

数组特性:

1.数组中的各元素的内存地址是连续的;

2.每个元素占用的空间大小相同(大小取决于初始化时的数据类型);

3.对于“ 要声明很多个相同数据类型的变量 ”的情况下,声明数组的方案是优选;

4.其实数组只是一个储存数组中第一个元素地址的容器;数组本身在栈内存中,其中的所有元素都按顺序,呈现条状储存在堆内存中;根据数组中储存的第一个元素的地址和不同的数组下标,就可以访问数组中其他的元素;

数组的 JVM 内存图:

如下图:

内存图解析:

像储存 int 这样的基本数据类型的变量 i ,就是直接储存的 “ 100 ” 的数据;

所有数组都是引用数据类型,像 int [ ]  array1 , 它储存了一串 int 数据中的第一个 int 的内存地址,地址对应的也就是堆内存中的“ 100 ”,这一串 int 数据的地址都是连续的,比如:100---0x11,5---0x12,23---0x13等等;

Person [ ]  array2 ,它储存的地址---0x22,对应的就是堆内存中“ 0x22 ”的那块空间,由于声明的是 Person 类型,所以堆内存“0x22”对应的那块空间中储存的也是地址---0x1234,这块地址对应的是 Person对象的内存空间,array2 中的其他的数组元素也是同理;

正如上图,一个数组为数组元素在堆内存中开辟的空间都是“ 条状 ” 的;

工具类方法---数组元素查找 ,排序,数组拷贝:

1.数组元素查找:

1)方法:Arrays . binarySearch ( 数组 , 数组元素 )

2)方法所在包: java . util . Arrays ;  /    java.util. * ;

3)方法返回值:若元素不存在,则返回 ” -1 “ ,若元素存在,则返回元素的数组下标;

4)栗子是最好的老师:

import java.util.Arrays;
public class pra {
public static void main(String[] args) {
int [] a={5,6,1,8,4};
int index=Arrays.binarySearch(a,8);
System.out.println(Arrays.binarySearch(a,8)==-1?"该元素不存在":"该元素的下标是:"+index);
}
} 运行结果:
----------------------
该元素的下标是:3 Process finished with exit code 0

2.排序:

1)方法:Arrays . sort( 数组 )

2)方法所在包: java . util . Arrays ;   /    java . util . * ;

3)作用:将数组中的元素按从小到大排序 ;

4)栗子是最好的老师:

import java.util.Arrays;
public class pra {
public static void main(String[] args) {
int [] a={5,6,1,8,4};
Arrays.sort(a);
for (int i=0;i<a.length;i++){
System.out.println(a[i]);
}
}
} 运行结果:
------------------------------
1
4
5
6
8 Process finished with exit code 0

3.数组拷贝;

1)方法:System . arraycopy ( 数组1,数组1起点下标,数组2,数组2起点下标,拷贝长度 ) ;

2)作用:以数组1起点下标,作为复制位置起点,以数组2起点下标,作为粘贴位置起点,拷贝长度作为拷贝元素个数;

3)栗子是最好的老师:

public class pra {
public static void main(String[] args) {
int []arr1={1,2,3};
int []arr2=new int [5];
System.out.println("未接收拷贝数据的arr2:");
for (int i=0;i<arr2.length;i++){
System.out.println(arr2[i]);
}
System.arraycopy(arr1,0,arr2,0,arr1.length);
System.out.println("接收了拷贝数据的arr2:");
for (int i=0;i<arr2.length;i++){
System.out.println(arr2[i]);
}
}
} 运行结果:
-----------------------------
未接收拷贝数据的arr2:
0
0
0
0
0
接收了拷贝数据的arr2:
1
2
3
0
0 Process finished with exit code 0

4)注意:实际拷贝的不是拷贝对象,而是拷贝对象的地址 ;

二分法查找:

1.概念:建立在对数组排序的基础上,查找数组中某一元素;

2.优点:降低了" 查找数组某一元素 "代码执行的复杂程度,使查找时间大幅度缩减;

3.栗子是最好的老师:

//先导包:(当然也可以写成:import java.util.*;)
import java.util.Arrays;
public class pra {
public static void main(String[] args) {
int [] a={5,6,1,8,4};
Arrays.sort(a);
int index=Arrays.binarySearch(a,8);
System.out.println(Arrays.binarySearch(a,8)==-1?"该元素不存在":"该元素的下标是:"+index);
}
} 运行结果:
----------------------
该元素的下标是:4 Process finished with exit code 0

注意:输出结果中的数组下标是指排序后的新数组的数组下标;

随笔:

1.对于要直接使用的方法来说,加上 static ,就十分方便了(不需要创建对象),比如上文中的遍历数组的方法;

2.可以直接向遍历数组的方法中传递一个静态数组:

printArray1 (  new int [ ] {   1,2,3  }  )  ;


由于博主目前只是一只猿宝宝,所以有些地方可能说的有些片面,若前辈们能够指点一二就更好了      (~ ̄(OO) ̄)ブ

【JAVA】笔记(7)--- 数组精讲的更多相关文章

  1. 深入Java核心 Java内存分配原理精讲

    深入Java核心 Java内存分配原理精讲 栈.堆.常量池虽同属Java内存分配时操作的区域,但其适用范围和功用却大不相同.本文将深入Java核心,详细讲解Java内存分配方面的知识. Java内存分 ...

  2. Java岗 面试考点精讲(基础篇01期)

    即将到来金三银四人才招聘的高峰期,渴望跳槽的朋友肯定跟我一样四处找以往的面试题,但又感觉找的又不完整,在这里我将把我所见到的题目做一总结,并尽力将答案术语化.标准化.预祝大家面试顺利. 术语会让你的面 ...

  3. Java集合详解8:Java的集合类细节精讲

    Java集合详解8:Java集合类细节精讲 今天我们来探索一下Java集合类中的一些技术细节.主要是对一些比较容易被遗漏和误解的知识点做一些讲解和补充.可能不全面,还请谅解. 本文参考:http:// ...

  4. Java笔记(八)……数组

    数组的概念 同一种类型数据的集合.其实数组就是一个容器. 数组的好处 可以自动给数组中的元素从0开始编号,方便操作这些元素. 数组的格式 元素类型[] 数组名 = new 元素类型[个数]; int[ ...

  5. Java笔记之数组

    1.int flags[] = new int[10];数组中的每个元素初始化为0. Arrays.fill(flags, 0);将数组中每个元素置为0.

  6. Java实现人民币大写精讲

    想要实现人民币大写,在发票等场景中使用?? 1234.56显示为:壹仟贰佰叁拾肆元伍角陆分,那就往下看看吧! 本程序可以实现 0 到 9999 9999 9999.994 以内的人民币大写转换,精确到 ...

  7. Java岗 面试考点精讲(基础篇02期)

    1. 两个对象的hashCode相同,则equals也一定为true,对吗? 不对,答案见下面的代码: @Override public int hashCode() { return 1; } 两个 ...

  8. [java笔记]动态数组

    private int count;//计数器 private int ary[] = new int [3]; if(count >= ary.length){ //数组动态扩展 int ne ...

  9. Java岗 面试考点精讲(网络篇03期)

    1. OSI七层模型 总结一下: 应用用层按协议打包数据 由传输层加上双方的端口号 由网络层加上双方的IP地址 由链路层加上双方的MAC地址,并将数据拆分成数据帧 数模信号转换并由物理层传输到另一端 ...

随机推荐

  1. WPF进阶技巧和实战03-控件(5-列表、树、网格04)

    ListView控件 ListView继承自简单的没有特色的ListBox,增加了对基于列显示的支持,并增加了快速切换视图或显示模式的能力,而不需要重新绑定数据以重新构建列表. ListView类继承 ...

  2. (一):细说贝叶斯滤波:Bayes filters

    认知计算,还要从贝叶斯滤波的基本思想讲起,本文主要是对<Probabilistic Robotics>中贝叶斯滤波器部分的详细讲解. 这一部分,我们先回顾贝叶斯公式的数学基础,然后再来介绍 ...

  3. Spring源码之创建AOP代理之增强器的获取

    前言 在上一篇博文中我们说到了通过自定义配置完成了对AnnotationAwareAspectJAutoProxyCreator类型的自动注册,那么这个类究竟做了什么工作从而完成AOP的操作呢?首先我 ...

  4. firewalld dbus接口使用指南

    firewalld,一个基于动态区的iptables/nftables守护程序,自2009年左右开始开发,最新版本 - 防火墙0.6.3 - 发布于2018年10月11日.主要的开发人员是托马斯·沃纳 ...

  5. VS运行时 /MD、/MDd 和 /MT、/MTd之间的区别

    程序运行时出现问题,选择的是Release,win64位的模式,并且已经看到了宏定义NDEBUG,但是程序依然进入上面的部分 解决方案是将属性->C/C++->代码生成器->运行库里 ...

  6. 初探JavaScript PDF blob转换为Word docx方法

    PDF转WORD为什么是历史难题 PDF 转Word 是一个非常非常普遍的需求,可谓人人忌危,为什么如此普遍的需求,却如此难行呢,还得看为什么会有这样的一个需求: PDF文档遵循iOS32000的规范 ...

  7. python和shell 取日期为今天的行

    按条件取行 todolist.txt是存储所有数据的地方,每次查看数据库显得麻烦. 在执行命令后,要在终端显示今日应作事项. 首先用linux 的shell脚本来实现该功能. grep指令可以在文件中 ...

  8. Linux搭建SVN服务器详细教程

    前言 本文讲解Linux系统下如何搭建SVN服务器,详细说明各配置项的功能,最终实现可管控多个项目的复杂配置. SVN是subversion的缩写,是一个开放源代码的版本控制系统,通过采用分支管理系统 ...

  9. 四万字32图,Kafka知识体系保姆级教程宝典

    本文目录: 一.消息队列 Apache Pulsar Pulsar 与 Kafka 对比 二.Kafka基础 三.Kafka架构及组件 四.Kafka集群操作 五.Kafka的JavaAPI操作 六. ...

  10. makedown笔记

    makedown语法 表格 这个表格的主题 |姓名|性别|年龄|职业| | ----- | ----- | ----- | ----- | |张三|男|34|码农| |李四|男|27|代驾| 这个表格 ...