【JAVA】数组的概念;数组的使用;引用;内存分区;数组练习题

这篇具有很好参考价值的文章主要介绍了【JAVA】数组的概念;数组的使用;引用;内存分区;数组练习题。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

🍉内容专栏:【JAVA从0到入门】

🍉本文脉络:数组的概念;数组的使用;引用;内存分区;数组练习题

🍉本文作者:Melon_西西

🍉发布时间 :2023.7.20

目录

1. 数组的基本概念

2数组的创建及初始化

2.1 数组的创建: T [ ] 数组名 = new T[N];

2.2 数组的初始化 : 动态初始化和静态初始化。

2.2.1. 动态初始化:在创建数组时,直接指定数组中元素的个数

2.2.2. 静态初始化:在创建数组时不直接指定数据元素个数,而直接将具体的数据内容进行指定

注意事项:

3. 数组的使用

3.1 数组中元素访问

3.2 遍历数组 

通过 数组对象.length 来获取数组的长度来遍历数组

 也可以使用 for-each 遍历数组

4. 数组是引用类型

4.1内存用来存储对象,不同的内存放不同数据:

4.2初始JVM的内存分布

4.2基本类型变量与引用类型变量的区别

 5.数组练习

5.1.拷贝,打印数组

Arrays.copyOf()拷贝克隆

5.2.拷贝输出局部数组

copyOfRange(数组,从下标1开始,到下标3);[1,3),java一般左闭右开

5.3.拷贝

 System.arraycopy(array, 0, copy4,  0, array.length);

5.4.求数组中元素的平均值

avg(arr)

5.5.查找数组中指定元素(顺序查找)

5.6 数组二分查找:先排序数组,再二分查找

使array数组有序  Arrays.sort(array);

5.7 数组逆序


1. 数组的基本概念

数组:相同类型元素的一个集合。在内存中是一段连续的空间。

1. 数组中存放的元素其类型相同

2. 数组的空间是连在一起的

3. 每个空间有自己的编号,其实位置的编号为0,即数组的下标。

2数组的创建及初始化

2.1 数组的创建: T [ ] 数组名 = new T[N];

T      :表示数组中存放元素的类型

T [ ] :表示数组的类型

N      :表示数组的长度


int [ ] array1        = new int [10];       // 创建一个可以容纳10个int类型元素的数组

double[ ] array2  = new double[5];  // 创建一个可以容纳5个double类型元素的数组

String[ ] array3  = new double[3];   // 创建一个可以容纳3个字符串元素的数组

2.2 数组的初始化 : 动态初始化和静态初始化。

2.2.1. 动态初始化:在创建数组时,直接指定数组中元素的个数

int[] array = new int[10];

2.2.2. 静态初始化:在创建数组时不直接指定数据元素个数,而直接将具体的数据内容进行指定

 T [ ] 数组名称 = {data1, data2, data3, ..., datan};

in t[ ] array1        = new int[ ]  {0,1,2,3,4,5,6,7,8,9};

double[ ] array2  = new double[ ] {1.0, 2.0, 3.0, 4.0, 5.0};

String[]  array3   = new String[ ] {"hell", "Java", "!!!"};:

注意事项:

静态初始化没有指定数组的长度,编译器在编译时会根据 { }中元素个数来确定数组的长度。

静态初始化时, {}中数据类型必须与[]前数据类型一致。

静态初始化可以简写,省去后面的 new  T [ ]

静态和动态初始化也可以分为两步,但是省略格式不可以:

int[] array1;                        int[ ] array2;

array1 = new int[10];         array2 = new int[]{10, 20, 30}

如果没有对数组进行初始化,数组中元素有其默认值 如果数组中存储元素类型为基类类型。

默认值为基类类型对应的默认值,比如:

( 如果数组中存储元素类型为引用类型,默认值为null )

【JAVA】数组的概念;数组的使用;引用;内存分区;数组练习题,开发语言

3. 数组的使用

3.1 数组中元素访问

数组在内存中是一段连续的空间,空间的编号都是从0开始的,依次递增,该编号称为数组的下标,数组可以通过 下标访问其任意位置的元素

数组是一段连续的内存空间,因此支持随机访问,即通过下标访问快速访问数组中任意位置的元素

下标从0开始,介于[0, N)之间不包含N,N为元素个数,不能越界,否则会报出下标越界异常。

3.2 遍历数组 

"遍历" 是指将数组中的所有元素都访问一遍, 访问是指对数组中的元素进行某种操作

通过 数组对象.length 来获取数组的长度来遍历数组

public class Text01 {
    public static void main(String[] args) {
        int[]array = new int[]{10, 20, 30, 40, 50};
        for(
                int i = 0; i < array.length; i++){
            System.out.println(array[i]);
        }
    }
}

 也可以使用 for-each 遍历数组

    int[] array1 = {1, 2, 3};
        for (int x : array1) {
            System.out.println(x);
        }

4. 数组是引用类型

4.1内存用来存储对象,不同的内存放不同数据:

1.程序运行时代码需要加载到内存

2. 程序运行产生的中间数据要存放在内存

3. 程序中的常量也要保存

4. 有些数据可能需要长时间存储,而有些数据当方法运行结束后就要被销毁

4.2初始JVM的内存分布

     程序计数器 (PC Register): 只是一个很小的空间, 保存下一条执行的指令的地址

     虚拟机栈(JVM Stack): 与方法调用相关的一些信息,每个方法在执行时,都会先创建一个栈帧,栈帧中包含 有:局部变量表、操作数栈、动态链接、返回地址以及其他的一些信息,保存的都是与方法执行时相关的一 些信息。比如:局部变量。当方法运行结束后,栈帧就被销毁了,即栈帧中保存的数据也被销毁了。

     本地方法栈(Native Method Stack): 本地方法栈与虚拟机栈的作用类似. 只不过保存的内容是Native方法的局 部变量. 在有些版本的 JVM 实现中(例如HotSpot), 本地方法栈和虚拟机栈是一起的

     堆(Heap): JVM所管理的最大内存区域. 使用 new 创建的对象都是在堆上保存 (例如前面的 new int[]{1, 2, 3} ),堆是随着程序开始运行时而创建,随着程序的退出而销毁,堆中的数据只要还有在使用,就不会被销 毁。

     方法区(Method Area): 用于存储已被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码等数 据. 方法编译出的的字节码就是保存在这个区域

4.2基本类型变量与引用类型变量的区别

基本数据类型创建的变量,称为基本变量,该变量空间中直接存放的是其所对应的值;

而引用数据类型创建的变量,一般称为对象的引用,其空间中存储的是对象所在空间的地址。

局部变量是在方法内部的变量,引用变量看里面存储的是不是地址

引用不可以指向引用,只能指向另一个引用所指的对象

null 在 Java 中表示 "空引用" , 也就是一个不指向对象的引用

    public static void func1(int[] array) {
        array = new int[10];
    }

    public static void func2(int[] array) {//
        // array[0]=99;
        array = null;
    }
    public static void main2(String[] args) {
        int[] array1 = {1, 2, 3, 4};
        func1(array1);
        for (int i = 0; i < array1.length; i++) {
            System.out.print(array1[i] + " ");
        }
        System.out.println();
        int[] array2 = {1, 2, 3, 4};
        func2(array2);
        for (int i = 0; i < array2.length; i++) {
            System.out.print(array2[i] + " ");
        }
        System.out.println();
    }
}

 5.数组练习

5.1.拷贝,打印数组

Arrays.copyOf()拷贝克隆

    public static void main(String[] args) {
        //打印数组
        int [] array ={1,2,3,4,5,6};
        int[ ]copy = Arrays.copyOf(array,array.length);//鼠标放在copyOf点ctrl可以看详细
        System.out.println( Arrays.toString(copy));
    }

5.2.拷贝输出局部数组

copyOfRange(数组,从下标1开始,到下标3);[1,3),java一般左闭右开

    public static void main(String[] args) {
            int [] array ={1,2,3,4,5,6};
            int[] copy2=Arrays.copyOfRange(array,1,3);
            System.out.println(Arrays.toString(copy2))
            //输出[2, 3]
        int[] copy3=Arrays.copyOfRange(array,1,13);
        System.out.println(Arrays.toString(copy3));
        //输出[2, 3, 4, 5, 6, 0, 0, 0, 0, 0, 0, 0]
    }

5.3.拷贝

 System.arraycopy(array, 0, copy4,  0, array.length);

       
    public static void main(String[] args) {
        int [] array ={1,2,3,4,5,6};
         // 拷贝
        int[] copy4 = new int[array.length];
        System.arraycopy(array, 0, copy4,  0, array.length);
        System.out.println(Arrays.toString(copy4));
        //[1, 2, 3, 4, 5, 6]
        //拷贝
        int[] copy5 = new int[array.length*2];
        System.arraycopy(array, 0, copy5,  0, array.length);
        System.out.println(Arrays.toString(copy5));
        //[1, 2, 3, 4, 5, 6, 0, 0, 0, 0, 0, 0]
   }

5.4.求数组中元素的平均值

avg(arr)

    public static void main(String[] args) {
        //求数组中元素的平均值
        int[] arr = {1,2,3,4,5,6};
        System.out.println(avg(arr));
    }
    public static double avg(int[] arr) {
        int sum = 0;
        for (int x : arr) {
            sum += x;
        }
        //注意这里要强制转换
        return (double)sum / (double)arr.length;
    }

5.5.查找数组中指定元素(顺序查找)

    public static void main(String[] args) {
        int[] arr = {1,2,3,10,5,6};
        System.out.println(find(arr, 10));
    }
    public static int find(int[] arr, int data) {
        for (int i = 0; i < arr.length; i++) {
            if (arr[i] == data) {
                return i;
            }
        }
        return -1; // 表示没有找到
    }

5.6 数组二分查找:先排序数组,再二分查找

使array数组有序  Arrays.sort(array);

    public static void main(String[] args) {
        int[] array = {1,2,13,4,15};
        Arrays.sort(array);
        System.out.println(Arrays.toString(array));
        //输出[1, 2, 4, 13, 15]
    }

完整代码:

    public static void main(String[] args) {
        int[] array = {1, 2, 13, 4, 15, 12};
        Arrays.sort(array);
        System.out.println(Arrays.toString(array));
        //输出[1, 2, 4, 13, 15]
        System.out.println(binarySearch(array, 13));//输出4
    }

    public static int binarySearch(int[] arr, int toFind) {
        int left = 0;
        int right = arr.length - 1;
        while (left <= right) {
            int mid = (left + right) / 2;
            if (toFind < arr[mid]) {
// 去左侧区间找
                right = mid - 1;
            } else if (toFind > arr[mid]) {
// 去右侧区间找
                left = mid + 1;
            } else {
// 相等, 说明找到了
                return mid;
            }
        }
        // 循环结束, 说明没找到
        return -1;
    }

5.7 数组逆序

    public static void main(String[] args) {
            int[] arr = {1, 2, 3, 4};
            reverse(arr);
            System.out.println(Arrays.toString(arr));
            //输出[4, 3, 2, 1]
        }
        public static void reverse(int[] arr) {
            int left = 0;
            int right = arr.length - 1;
            while (left < right) {
                int tmp = arr[left];
                arr[left] = arr[right];
                arr[right] = tmp;
                left++;
                right--;
            }
        }

5.8数组元素扩大两倍:两种方法


public class Text02 {
    //数组元素扩大两倍
    public static void main(String[] args) {
        int[] array = {1,2,3,4,5};
        System.out.println(Arrays.toString(array));
        //[1, 2, 3, 4, 5]
        transform(array);//它修改的是原数组的数据
        System.out. println(Arrays.toString(array)) ;
        //[2, 4, 6, 8, 10]
        int[] array1 = {1,2,3,4,5};
        System.out. println(Arrays.toString(array1)) ;
        //[1, 2, 3, 4, 5]
        int[] ret = transform2(array1);
        System.out.println(Arrays.toString(ret));
        //[2, 4, 6, 8, 10]
    }
    public static void transform(int[] array){
        for (int i = 0; i< array. length; i++) {
            array[i] = array[i]*2;
        }
    }
    public static int[] transform2(int[ ] array) {
        int[] ret = new int[array.length];
        for (int i = 0;i< array.length; i++){
            ret[i] = array[i]*2;
        }
        return ret;
    }
}

 


写在最后:

博主大一学识尚浅,内容仅供参考,欢迎大家在评论区交流分享。

目前从0开始学习JAVA,记录学习心得,期待认识志同道合的伙伴们,欢迎关注^_^文章来源地址https://www.toymoban.com/news/detail-600178.html

到了这里,关于【JAVA】数组的概念;数组的使用;引用;内存分区;数组练习题的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 树状数组练习题

    为什么大佬们一眼看出是树状数组呢? 不是一眼看出树状数组,而是 要把 【找两个相邻的最小值之间还有几个数没删掉】 的问题转变成动态区间和问题,这个转化过程才是最重要的 , 至于你用什么数据结构求动态区间和是次要的,很多数据结构都能做,最常用的树状数组

    2024年02月03日
    浏览(39)
  • C语言之数组练习题

    第1关:数组插入元素 300 任务要求 参考答案 评论106 任务描述 相关知识 数组 数组元素的表示方法 编程要求 测试说明 任务描述 本关需要你将一个数插入到一组已经排好序的数组并输出。 相关知识 数组在程序设计中,为了处理方便, 把具有相同类型的若干变量按有序的形式

    2024年02月05日
    浏览(51)
  • 数据结构与算法--图(概念+练习题+解析)

    有向图 在有向图中有以下几点结论: 1.所有顶点的度数之和等于边数的二倍。 2.所有顶点的入度之和等于出度之和。 3.n个顶点的有向完全图有n(n-1)条边。 4.n个顶点的强连通图至少有n条边。 无向图 在无向图中有以下几点结论: 1.所有顶点的度数之和等于边数的二倍。 2.n个顶

    2024年02月04日
    浏览(42)
  • C语言——指针和数组练习题解析

    学习了指针的初阶和进阶后,已经对指针有了一定了解。下面就需要做题目,去巩固所学的知识。 对数组名的理解: 数组名是数组首元素的地址,但是由两个例外 sizeof(数组名),这里的数组名表示整个数组,计算的是整个数组的大小。 数组名,这里的数组名是整个数组,

    2024年02月16日
    浏览(56)
  • C++核心编程——内存分区、引用、函数提高和函数重载

    本专栏记录C++学习过程包括C++基础以及数据结构和算法,其中第一部分计划时间一个月,主要跟着黑马视频教程,学习路线如下, 不定时更新,欢迎关注 。 当前章节处于: ---------第1阶段-C++基础入门 ---------第2阶段实战-通讯录管理系统, ==== 第3阶段-C++核心编程 , --------

    2024年01月22日
    浏览(32)
  • C++ 命名空间、域、缺省参数、函数重载、引用、auto、内联函数的知识点+完整思维导图+基本练习题+深入细节+通俗易懂建议收藏

            从本章开始我们正式进入到C++的内容,对此如果没有学习过C语言的建议先将C语言系统的学习一遍后再来(已经更新完在专栏就能看到)。 话不多说安全带系好,发车啦 (建议电脑观看) 。 附:红色,部分为重点部分;蓝颜色为需要记忆的部分(不是死记硬背哈,

    2023年04月24日
    浏览(98)
  • 数据库SQL语言实战(五)(数据库系统概念第三章练习题)

    目录 前言知识 一、 关系模式 二、 属性域 例子 介绍 作用 三、Select常数 举例 解释  四、集合差运算 本质 举例  结论 练习题 3.17 3.18  3.21  总结  注:本文的SQL语言适用的是 Oracle数据库 与mySQL可能存在略微不同 模式的定义 :模式则是指数据库中 所有关系模式 的集合,它

    2024年04月22日
    浏览(59)
  • 【Java练习题汇总】《第一行代码JAVA》综合测试三,汇总Java练习题

    线程的启动方法是( )。 A. run() B. start() C. begin() D. accept() Thread 类提供表示线程优先级的静态常量,代表普通优先级的静态常量是( )。 A. MAX_PRIORITY B. MIN_PRIORITY C. NORMAL_PRIORITY D. NORM_PRIORITY 设置线程优先级的方法是( )。 A. setPriority() B. getPriority() C. getName() D. setName() 下面 ( )方法是

    2024年02月14日
    浏览(46)
  • 【运维知识高级篇】34道Shell编程练习题及答案(从基础到实战:基础+计算+判断+循环+控制与数组+实战进阶)

    ​本篇文章几乎涵盖了绝大部分的Shell语法练习,用一个个实战练习,巩固Shell的学习,话不多说,直接开始。 练习1:按照时间生成文件\\\"2018-05-22.log\\\"将每天的磁盘使用状态写入到对应日期的文件 练习2:统计Nginx日志中每个IP的访问量有多少,日志格式如下 练习3:写一个脚本

    2024年02月14日
    浏览(58)
  • java -- 练习题

    1.定义一个Person类,要求有姓名和年龄,并且符合JavaBean标准,定义Student类继承Person,定义测试类,创建Student对象,要求创建Student对象的同时,指定Student对象的姓名为\\\"张三\\\",只能指定姓名不许指定年龄 2.按照以下要求定义类 3.键盘录入一个字符串,判断这个字符串是否是对称的字符串

    2023年04月09日
    浏览(36)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包