Java_引用变量

article/2025/9/14 21:11:04

目录

1.认识 null

​编辑 2.数组的应用

3.数组作为函数的参数 

 4.数组作为函数的返回值

 5.数组练习

数组转字符串

 6.数组拷贝

 (1)通过函数Arrays.copyOf()进行拷贝:

 (2)通过函数System.arraycopy()进行拷贝: 

(3)拷贝范围Arrays.copyOfRange()

(4)比较两个数组是否相等Arrays.equals()

(5)对数组进行填充Arrays.fill()

 7.深浅拷贝

8.在数组中查找一个元素

1.认识 null

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

 2.数组的应用

3.数组作为函数的参数 

参数传类型(引用数据类型)

总结:当数组作为参数进行传递的时候,其实还是按值传递的,只不过传递的值是一个地址。那么会出现两种情况:

1.形参改变指向:array = new int[10];只会影响形参的指向。

2.形参修改指向对象的值:array[0] = 9;此时才会影响实参。 

 4.数组作为函数的返回值

 

 5.数组练习

数组转字符串

public static String myToString(int[] array) {if (array == null) {return "null";}String ret = "[";for (int i = 0; i < array.length; i++) {ret += array[i];if (i != array.length - 1) {ret += ", ";}}ret = ret + "]";return ret;}public static void main(String[] args) {int[] array = {1,2,3,4};System.out.println(myToString(array));}

 6.数组拷贝

//数组拷贝public static void main(String[] args) {int[] array = {1,2,3,4};int[] array2 = new int[array.length];for (int i = 0; i < array.length; i++) {array2[i] = array[i];}System.out.println(Arrays.toString(array));System.out.println(Arrays.toString(array2));}

 (1)通过函数Arrays.copyOf()进行拷贝:

public static void main(String[] args) {int[] array = {1,2,3,4};//可以当作扩容int[] ret = Arrays.copyOf(array, array.length);System.out.println(Arrays.toString(array));System.out.println(Arrays.toString(ret));int[] ret2 = Arrays.copyOf(array, array.length*2);System.out.println("--------------------");System.out.println(Arrays.toString(ret2));}

 

 (2)通过函数System.arraycopy()进行拷贝: 

public static void main(String[] args) {int[] array = {1,2,3,4};int[] copy = new int[array.length];System.arraycopy(array, 0, copy, 0, array.length);System.out.println(Arrays.toString(array));System.out.println(Arrays.toString(copy));int[] copy2 = new int[array.length];System.arraycopy(array, 1, copy2, 1, array.length-1);//从array数组下标为1的元素开始拷,只能拷3个,所以长度-1System.out.println(Arrays.toString(copy2));}

import java.util.Arrays;public static void func(){
// newArr和arr引用的是同一个数组
// 因此newArr修改空间中内容之后,arr也可以看到修改的结果int[] arr = {1,2,3,4,5,6};int[] newArr = arr;newArr[0] = 10;System.out.println("newArr: " + Arrays.toString(arr));
// 使用Arrays中copyOf方法完成数组的拷贝:
// copyOf方法在进行数组拷贝时,创建了一个新的数组
// arr和newArr引用的不是同一个数组arr[0] = 1;newArr = Arrays.copyOf(arr, arr.length);System.out.println("newArr: " + Arrays.toString(newArr));
// 因为arr修改其引用数组中内容时,对newArr没有任何影响arr[0] = 10;System.out.println("arr: " + Arrays.toString(arr));System.out.println("newArr: " + Arrays.toString(newArr));
// 拷贝某个范围.int[] newArr2 = Arrays.copyOfRange(arr, 2, 4);System.out.println("newArr2: " + Arrays.toString(newArr2));}

(3)拷贝范围Arrays.copyOfRange()

public static void main(String[] args) {int[] array = {1,2,3,4,5};int[] ret = Arrays.copyOfRange(array, 1, 3);//[1,3)System.out.println(Arrays.toString(array));System.out.println(Arrays.toString(ret));}

(4)比较两个数组是否相等Arrays.equals()

public static void main(String[] args) {int[] array1 = {1,2,3,4,5};int[] array2 = {1,2,3,4,5};System.out.println(Arrays.equals(array1,array2));}

(5)对数组进行填充Arrays.fill()

public static void main(String[] args) {int[] array = new int[10];Arrays.fill(array, 3);System.out.println(Arrays.toString(array));}

 局部赋值:

public static void main(String[] args) {int[] array = new int[10];Arrays.fill(array, 3);System.out.println(Arrays.toString(array));//局部赋值——将4~7的位置赋值为9Arrays.fill(array, 3, 7, 9);//[3,7)System.out.println(Arrays.toString(array));}

 (6)数组名.clone()——>产生一个副本

public static void main(String[] args) {int[] array1 = {1,2,3,4,5};int[] array2 = array1.clone();System.out.println(Arrays.toString(array1));System.out.println(Arrays.toString(array2));System.out.println("-----------------------");array2[0] = 100;System.out.println(Arrays.toString(array1));System.out.println(Arrays.toString(array2));}

 7.深浅拷贝

8.在数组中查找一个元素

public static int find(int[] array, int val) {for (int i = 0; i < array.length; i++) {if (array[i] == val) {return i;}}return -1;}public static void main(String[] args) {int[] array = {1,2,3,4,5};int ret = find(array, 2);//这个方法效率极低System.out.println(ret);//1(下标为1)}

http://chatgpt.dhexx.cn/article/eynHSgsM.shtml

相关文章

C++中的引用变量详解

文章目录 声明及定义代码引用变量的特点图片解释引用变量的本质引用变量的用途int & 和 const int & 的区别引用变量和宏定义&#xff08;#define&#xff09;的区别 声明及定义 [const] int& 变量名 右值 注意&#xff1a;[]内的是可选的。即这里的const限定词是…

引用变量及其作用

首先&#xff0c;先来明白一下什么是引用变量。 一个变量可以声明为一个引用&#xff0c;它起着该变量的别名的作用。对引用进行操作&#xff0c;实际上就是对被引用的变量进行操作。 引用运算符&#xff1a;&&#xff1b; 定义的一般形式&#xff1a;数据类型 &引用变…

变量的引用

引用是C对C的一个重要扩充。 1、引用的概念&#xff1a;变量的引用就是变量的别名。引用不是新定义一个变量&#xff0c;而是给已存在变量取了一个别名&#xff0c;编译器不会为引用变量开辟内存空间&#xff0c;它和它引用的变量共用同一块内存空间。 从上面图中就可以看出&a…

引用变量

引用就是一个变量的别名&#xff0c;声明&#xff1a; int a 0; int &b a; b就是a的引用&#xff0c;a和b指向的内存时同一个地址&#xff0c;b可以修改变量的值 一。主要的用途是将引用变量作为函数的参数传递&#xff0c;为什么呢&#xff1f; &#xff08;1&…

C++入门基础—— 引用变量

目录 什么是引用&#xff1a; 引用的例子 引用的特性&#xff1a; 常量引用与非常量引用 使用场景 引用与指针的区别 什么是引用&#xff1a; 引用的概念 引用实际上就是取别名&#xff0c;提起这个名字就会让人知道是谁&#xff0c;谈起“鸡哥”就知道是坤坤&#xff0c;…

C++——引用变量

目录 一、创建引用变量 二、将引用作为函数参数 三、引用的属性和特别处 四、临时变量、引用参数和const 五、返回引用 六、何使用引用参数 七、参考书籍 引用变量是C新增的一种复合类型。引用是已定义的变量的别名&#xff08;另一个名字&#xff0c;但两个名字都是表示…

014 变量的引用

目标&#xff1a; 1、变量的引用 2、可变和不可变量类型 3、局部变量和全局变量 一、变量的引用 。变量 和 数据 都是保存在 内存 中的 。在 python 中 函数 的 参数传递 以及 返回值 都是靠 引用 传递的 1.1 引用的概念 在 Python 中 。变量 和 数据 是分开存储的 。数据 保…

C语言动态内存分配函数

目录 1.malloc()2.free()3.calloc()4.realloc()5.小结 在C中我们开辟内存空间有两种方式 :1.静态开辟内存 : 例如: int a; int b[10]; 这种开辟内存空间的特点是 所开辟的内存是在栈中开辟的固定大小的 ,如a是4字节 ,数组b是40字节 ,并且数组在申明时必须指定其长度 , 如果是全…

【C语言】------ 动态内存分配

动态内存开辟详解 动态内存分配什么是动态内存分配&#xff1f; 一、为什么使用动态内存分配呢&#xff1f;二、动态内存函数1.malloc和free2.calloc和realloc 三、常见的动态内存错误1.对NULL指针的解引用操作2.对动态内存开辟的越界访问3.向free传递一个非malloc函数返回的指…

【C语言】为什么存在动态内存分配

文章目录 前言一、动态内存分配定义 二、动态内存分配的意义1.可以控制所开辟的内存大小2.可以多次利用这部分空间 三&#xff0c;动态内存函数的介绍 前言 提示&#xff1a;我们先来看一个在vs编译器下&#xff0c;同学们常犯的错误 注意&#xff1a;在VS编译器下C语言是不支…

静态内存分配与动态内存分配

静态内存分配与动态内存分配 动机 平时看c/c的书籍时&#xff0c;总会看到一种观点&#xff0c;说是C/C语言使用的时候动态内存分配是最重要的&#xff0c;使用malloc等函数分配的内存必须要释放&#xff0c;否则及其容易出现内存泄露。但是自己有时候挺奇怪的&#xff0c;啥…

JVM内存分配机制

Java虚拟机最重要的工作就是如何给对象分配内存空间&#xff0c;以及通过GC如何回收已经不再使用的内存空间。这篇文章主要介绍JVM中的Java对象是创建过程、对象内存的分配机制以及对象内存的回收机制。 一、对象的创建 在前面的文章《JVM类加载机制》中讲过&#xff0c;JVM中…

C语言动态内存分配详解

文章目录 前言一、为什么存在动态内存分配1、已掌握的内存开辟方式2、上述开辟空间方式的特点3、为什么存在动态内存分配 二、动态内存函数的介绍1、malloc2、free3、calloc4、realloc 三、常见的动态内存错误1、对NULL指针的解引用操作2、对动态开辟内存的越界访问3、对非动态…

动态内存管理(内存的分配与回收)详解

** 1. 数据结构之动态内存管理机制 ** 通过前面的学习&#xff0c;介绍很多具体的数据结构的存储以及遍历的方式&#xff0c;过程中只是很表面地介绍了数据的存储&#xff0c;而没有涉及到更底层的有关的存储空间的分配与回收&#xff0c;从本节开始将做更深入地介绍。 在使…

关于C++的动态内存分配

为什么要使用动态内存分配&#xff1f; 比较常见的情况是当我们使用一个数组时&#xff0c;我们需要去声明它&#xff0c;同时我们还需要提供给它一个编译时常量用于指定数组的长度。但是&#xff0c;我们有时候需要的数组并不是定长的。例如&#xff0c;我们要存储一个班级所…

【C语言】动态内存的分配

目录 &#x1f34b;&#x1f34b;前言 &#x1f34b;&#x1f34b;动态内存分配的定义 &#x1f34b;&#x1f34b;动态内存的优势 &#x1f34b;&#x1f34b;<1> 可以控制内存的大小 &#x1f34b;&#x1f34b;<2> 可以多次利用这部分空间 &#x1f34b;…

动态内存分配函数

一、静态存储分配与动态存储分配&#xff1a; &#xff08;1&#xff09;静态存储分配 通常定义变量&#xff08;或对象&#xff09;&#xff0c;编译器在编译时都可以根据该变量&#xff08;或对象&#xff09;的类型知道所需内存空间的大小&#xff0c;从而系统在适当的时候…

内存动态分区分配算法

文章目录 动态分区分配1. 首次适应算法&#xff08;First Fit&#xff09;2. 邻近适应算法&#xff08;Next Fit&#xff09;3. 最佳适应算法&#xff08;Best Fit&#xff09;4. 最坏适应算法&#xff08;Next Fit&#xff09; 总结 动态分区分配 所谓动态分区分配&#xff0…

C++之new动态分配内存生成数组

【任务1】&#xff1a; 编写并测试3*3矩阵转置函数&#xff0c;使用数组保存3*3矩阵。 实验要求 &#xff08;1&#xff09; 转置函数参数为二维数组&#xff1b; &#xff08;2&#xff09; 在main函数中实现输入、输出 #include <iostream> using namespace std…

C语言中的动态内存分配

大家好&#xff0c;今天简单讲一讲C语言中的动态内存分配。 补充&#xff1a;C程序中的内存块。 在C程序中&#xff0c;通常将内存划分为以下六个区域&#xff1a; &#xff08;1&#xff09;内核区域。这块区域是操作系统的&#xff0c;用户不能使用。 &#xff08;2&…