数组

  • 数组时相同类型数据的有序集合

  • 数组描述的时相同类型的若干数据,按照一个定的先后次序排列组合而成

  • 其中,每一个数据成为数组元素,每个数组元素可以通过一个下标来访问他们

数组的声明&创建

  • 首先必须声明数组变量,才能在程序中使用数组。 声明数组变量的语法:

dataRype[] arrayRefVar; // 首先的方法(java)
或者
dataType arrayRefVar[];// 效果相同,但不是首先方法
  • java语言使用new操作符来创建数组。

dataType[] arrayRefVar = new dataType[arraySize] ;
  • 数组的元素是通过索引访问的,数组索引从0开始。

    • 获取数组的元素:array.length

    public static void main(String[] args) {
       // 建立数组的基本步骤:
       // 1. 声明一个数组
       int[] nums;
       // 2. 创建一个数组(开辟空间)
       nums = new int[10];
       // 3. 给数组中的元素赋值
       for (int i = 0; i < nums.length; i++) {
           nums[i] = i+1 ;
      }
       
       for (int x : nums) {
           System.out.println(x);
      }
  }

内存分析

java内存:1 堆,2 栈,3 方法区

  1. 堆:可以存放new的对象和数组。(可以被所有的线程共享,不会存放别的对象引用)

  2. 栈:存放基本变量类型(包含这个基本变量类型的具体数值);引用对象的变量(会存放这个引用在堆里面的具体地址)

  3. 方法区:可以被所有的线程共享,包含了所有的class和static变量

由于数组的边界时,时确定的,在超出时,会报错:java.lang.ArrayIndexOutOfBoundsException。

数组的初始化

  1. 静态初始化:

int[] a ={1,2,3};
Man[] mans ={new Man(1,1),new Man(2,2)}
  1. 动态初始化:

int[] a = new int[2];
a[0]=1;
a[1]=2;
  1. 数组的初始化:

    • 数组时引用类型,它的元素相当于类的实例变量,因此数组一经分配空间,其中的元素同样被按照实例的变量同样的方式被隐形初始化。

数组的基本特点

  1. 数组的长度是确定的。数组一旦被创建,他的大小就不可以改变的。

  2. 其元素必须是相同类型,不允许出现混合类型。

  3. 数组中的元素可以是任何数据类型的,包括基本类型和引用类型。

  4. 数组变量属于引用类型,数组也可以看成对象,数组中的每个元素都相当于该对象的成员变量 数组本身就是对象,java中对象实在堆中的,因此数组无论保存原始类型还是其他对象类型,数组对象本身在堆中的

数组的边界

  • 下标的合法区间:[0,length-1],如果越界就会报错。

  • java.lang.ArrayIndexOutOfBoundsException。

数组小结

  • 数组时相同数据类型(任意类型)的有序集合

  • 数组也是对象,数组的元素相当于对象的成员变量

  • 数组的长度是确定的。越界就会报错。

数组的使用

  • 普通的for循环

  • for-each循环(增强型for循环)

  • 数组作方法入参

  • 数组做返回值

public class ArrayDemo04 {
   public static void main(String[] args) {
       int[] array = {1,2,3,4,5};
       // 增强for循环,适合打印输出
       for (int x : array) {
           System.out.println(x);
      }
       System.out.println("===========");
       printArray(array);
       System.out.println();
       System.out.println("$$$$$$$$$$$$");
       
       int[] reverse = arrayReverse(array);
       System.out.println("输入的反转数组如下:");
       printArray(reverse);
  }
   //打印数组
   public static void printArray (int[] array){
       for (int i = 0; i < array.length; i++) {
           System.out.print(array[i]+"\t");
      }
       System.out.println();
       System.out.println("*****************");
       for (int i = 0; i < array.length; i++) {
           System.out.print(array[i]+" ");
      }
  }
   //反转数组(返回值为数组)
   public static int[] arrayReverse (int[] array){
       int[] result= new int[array.length];
       for (int i = 0; i < array.length; i++) {
           result[i] = array[array.length-1-i];
      }
       return result;
  }
}

java基础——数组及其应用的更多相关文章

  1. Java基础——数组应用之StringBuilder类和StringBuffer类

    接上文:Java基础——数组应用之字符串String类 一.StringBuffer类 StringBuffer类和String一样,也用来代表字符串,只是由于StringBuffer的内部实现方式和 ...

  2. java基础-数组的折半查找原理

    java基础-数组的折半查找原理 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 如果让你写一个数组的查找功能,需求如下:在一个数组中,找一个元素,是否存在于数组中, 如果存在就返回 ...

  3. Java基础-数组常见排序方式

    Java基础-数组常见排序方式 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 数据的排序一般都是生序排序,即元素从小到大排列.常见的有两种排序方式:选择排序和冒泡排序.选择排序的特 ...

  4. 《Java基础——数组的定义与使用》

    Java基础--数组的定义与使用       一. 一维数组: 格式一: 数组类型 数组变量[]=new 数据类型[长度]; //需要后续赋值,且后续赋值时只能为单个元素赋值. 或 数组类型 数组变量 ...

  5. Java基础——数组Array

    一.数组基本概念 数组是相同类型数据的有序集合. 数组描述的是相同类型的若干个数据,按照一定的先后次序排列组合而成.其中,每一个数据称作一个数组元素,每个数组元素可以通过一个下标来访问它们. 数组有三 ...

  6. Java基础--数组(Arrays)

    数组(Array),是多个相同类型数据按一定顺序排列 的集合,并使用一个名字命名,并通过编号的方式 对这些数据进行统一管理.本篇博客是对Java基础中的数组进行详细说明. 目录: 数组的概述 一维数组 ...

  7. java基础---数组的基本概念(1)

    学习资源来自尚硅谷java基础学习 1. 数组的概念 数组(Array), 是多个相同类型数据按一定顺序排列的集合, 并使用一个名字命名, 并通过编号的方式对这些数据进行统一管理. 数组属于引用数据类 ...

  8. JAVA基础——数组详解

    学习JAVA中数组的使用 一.什么是数组? 问:编写代码保存 4 名学生的考试成绩. 答:简单啊,定义 4 个变量呗 问:那"计算全年级 400 名学生的考试成绩",肿么办 答: ...

  9. Java基础——数组复习

    数组是一个变量,存储相同数据类型的一组数据 声明一个变量就是在内存空间划出一块合适的空间 声明一个数组就是在内存空间划出一串连续的空间 数组长度固定不变,避免数组越界   数组是静态分配内存空间的,所 ...

  10. Java基础——数组应用之字符串String类

    字符串String的使用 Java字符串就是Unicode字符序列,例如串“Java”就是4个Unicode字符J,a,v,a组成的. Java中没有内置的字符串类型,而是在标准Java类库中提供了一 ...

随机推荐

  1. 学习一下 SpringCloud (六)-- 注册中心与配置中心 Nacos、网关 Gateway

    (1) 相关博文地址: 学习一下 SpringCloud (一)-- 从单体架构到微服务架构.代码拆分(maven 聚合): https://www.cnblogs.com/l-y-h/p/14105 ...

  2. java进阶(40)--wait与notify(生产者与消费者模式)

    文档目录: 一.概念 二.wait的作用 三.notify的作用 四.生产者消费者模式 五.举例 ---------------------------------------分割线:正文------ ...

  3. [状压DP]车II

    车 I I 车II 车II 题目描述 有一个 n ∗ m n*m n∗m的棋盘 ( n . m ≤ 80 , n ∗ m ≤ 80 ) (n.m≤80,n*m≤80) (n.m≤80,n∗m≤80)要 ...

  4. [BFS]翻币问题

    翻币问题 Description 有N个硬币(6<=N<=20000)全部正面朝上排成一排,每次将其中5个硬币翻过来放在原位置,直到最后全部硬币翻成反面朝上为止.试编程找出步数最少的翻法, ...

  5. HTML(一):语法结构

    HTML语法规范 基本语法概述 HTML标签是由尖括号包围的关键词,例如<html>. 2HTML标签通常是成对出现的,例如<html>和</html> ,我们称为 ...

  6. Sentinel上生产环境只差一步,监控数据持久化

    之前介绍了Sentinel相关的文章,小伙伴在生产实践中不知道有没有这个疑问?我们的Sentinel控制台监控的数据只能看最近5分钟的,如图 那么就导致历史数据是查看不了的,那肯定是不行的,在生产环境 ...

  7. Ugly Numbers UVA - 136

    Ugly numbers are numbers whose only prime factors are 2, 3 or 5. The sequence 1, 2, 3, 4, 5, 6, 8, 9 ...

  8. H5 hybrid开发-前端资源本地化方案纪要

    H5 hybrid-前端资源本地化方案纪要 就整个行业来说,大前端是趋势,现阶段,native方面除了一些偏CPU密集型工作与操作系统底层API方面的工作外,H5基本都可以满足需要. 目前的工作更偏向 ...

  9. 1086 Tree Traversals Again

    An inorder binary tree traversal can be implemented in a non-recursive way with a stack. For example ...

  10. hdu1146

    题意:       题意最蛋疼,其实是水题,这个题意整的我wa了一个多小时,我就改改题意吧..有一条河,刚开始的时候在左岸有一条船,这条船最多能运n个货物,一趟的时间是t,有m个货物,每个货物有自己到 ...