【Java图文趣味版】快速搞定数组的声明、开辟空间和初始化赋值

0 前言

本文讲解java数组的基础知识,适合零基础小白。

1 数组的概念

所谓数组,就是一组同类型东西的集合,可以通过index(索引,下标)访问这一组东西的某一个元素。

就像下图这样,由于数组概念过于简单,不解释了。
在这里插入图片描述

2 数组的定义及使用

2.1 数组的声明(Declare an array)

所谓声明,就是告诉你,这里有这么个东西,但是它既没有空间,也没有数值,在被使用之前,它可以看做 “一句空话”

有以下两种写法

int a [];
int [] b;

顺便说一句,这两种形式都可以声明数组,但是在Java中,通常我们使用后者,之后的内容也全部使用int [] b的形式。
在这里插入图片描述

2.2 数组的声明和开辟内存空间(Open up a memory space)

声明一个数组,并且为它开辟一个空间,占个地方,但是不在里面存放东西

有以下写法

int [] a = new int [4];

在这里插入图片描述
另外,可能出现没有占到地方的情况,我们后面会说(第4节)。

2.3 数组的声明、开辟内存空间和初始化赋值(Initialize an array)

有以下两种写法

int [] a = {11,22,33,44};
int [] b = new int [] {11,22,33,44};

在这里插入图片描述
对于以下语句

new int [] {11,22,33,44};

它的本质,是一个匿名数组,就是不宣布数组的名称,但是仍然创建了一个数组。因此它可以作为一个游荡的数组,灵活使用于很多场景。

例如

return new int [] {1,2,3,4};

对于任意的,只需要使用数组,但是不需要定义数组名称的地方,都可以使用这个表达式。
在这里插入图片描述
另外,可能出现赋空值的情况,比如直接就是{},里面没有东西,我们在后面会说明(第4节)。

2.4 声明之后如何开辟空间和赋值

做出声明之后

int [] a;

如何开辟空间和赋值呢?

  1. 首先,关于开辟空间,和前面完全一样,只不过把2.2节的语句int [] a = new int [4];拆开写了
int [] a;
a = new int [4];
  1. 然后,关于赋值,同理,结合2.3节的语句,也是拆开写了
int [] a;
a = new int [4];
a[0] = 11;
a[1] = 22;
a[2] = 33;
a[3] = 44;

或者使用另外一条语句

int [] a;
a = new int [] {11,22,33,44};

2.5 声明和开辟空间之后如何赋值

int [] a = new int [4];

在这之后,如何赋值,我就不多说了。

a[0] = 11;
a[1] = 22;
a[2] = 33;
a[3] = 44;

当然怎么赋值都可以,需要注意的是开辟空间后的数组的访问方式,对于a[0]这样的语句是什么意思,我们后面说。

2.6 赋值之后如何使用

通过下标访问即可,只要是开辟了空间或者已经赋值的,都可以这样,例如a[0],需要注意几点

  • 下标从0开始,可以是变量,例如int zero = 0;访问的时候可以写a[zero];
  • 开辟空间后,数组长度固定(变长数组以后再说)

3 在项目中规范化地定义和使用数组

不建议直接出现数字,因为数字的含义有很多,时间长了自己可能不记得数字的具体含义,其他程序员看到这个数字,也可能会费解,因此,建议将数字符号化,例如:

存储10个学生的总分数

建议这样使用

int studentCount = 10;
double [] studentSumScore = new double [studentCount];

而不是下面这种写法

double [] studentSumScore = new double [10];

这样的写法,对于复杂的程序,时间长了,可能会迷茫,10代表啥?这是啥?
在这里插入图片描述
你也许会说,不是可以有注释吗?我只能告诉你:能在程序中说明白的,就不要添加注释

另外,关于数组的访问,也可以参考,比如把studentSumScore[0]写成studentSumScore[stuOne]

具体有没有必要,还是结合实际,如果是徒增麻烦,就不要用了。

4 数组中的特殊值:0与null

首先明确一下,先分成两类

  1. 针对数组本身: 数组的长度为0和数组本身为null
  2. 数组元素内容: 数组不为0,数组元素的值为0或者为null

0与null的含义

  • 二者本质上,都是某种具有含义的特殊数值
  • 0就是空empty,本身存在,但是没有内容,啥都没有
  • null就是虚无,就是本身不存在,更没有内容

4.1 数组本身

数组长度为0,空数组,但是为其分配了内存空间的位置(有一席之地)

int[] a = new int[0];
int[] b = new int[]{};

在这里插入图片描述
数组为null,系统没有为其分配其内存空间(没有地方,只能流浪)

int[] c = null;

在这里插入图片描述

4.2 数组元素内容

前提是,创建了一个非空的数组。

这里特指:为一个数组开辟了空间但是没有赋值时候,数组元素的值可能为0,可能为null

例如以下形式,其中,int可以代表基本数据类型和引用数据类型(float,boolean,String)

int[] a = new int[4];

其中

  • 数值型的数据类型,默认初始化为0
  • 字符型,默认为空字符
  • 布尔型,默认为false
  • 对象(引用数据类型),比如String,默认为null

以下为实例测试

int[] b = new int[10];
System.out.println("int默认:\t"+b[0]);boolean[] g = new boolean[4];
System.out.println("boolean默认:"+g[0]);char[] w = new char[4];
System.out.println("char默认:\t"+w[0]);String[] c = new String[10];
System.out.println("String默认:\t"+c[0]);

输出结果为
在这里插入图片描述
下一篇文章:【java图文趣味版】数组元素的访问与遍历

本文中图片使用亿图图示(试用版)制作,之后截图上传,侵删。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/384732.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【java图文趣味版】数组元素的访问与遍历

0 前言 本文适合零基础小白。 本文接上一篇文章:快速搞定数组的声明、开辟空间和初始化赋值 重要的知识点 通过array index访问数组使用for each循环遍历数组使用Arrays.toString()方法打印数组 我们先创建一个数组,之后通过它来说明后面的知识。 …

初来乍到,多多关照。

从今天开始就要开始写博客了,把学到的知识都在这里记录下来,希望可以坚持,并且学到东西。

【MySQL】AUTO_INCREMENT只能应用于数值类型的列,且该列需要被索引

MySQL中的自动增量AUTO_INCREMENT,是有使用条件的 该列(column)的数据类型必须是数值型(这点容易理解,数值才能自增)该列必须被索引,比如定义为主键(PRIMARY KEY) 感悟…

【数据库】数据模型基础概念(图文版)

0 前言 本文通过一个实例,来讲解数据模型的基础概念。 要求设计一个数据库的数据模型,统计出你的宿舍每个人(4个人)的信息,要求包括 个人信息:学号、姓名、班级、年级、学院选课情况:学号、课程…

利用SIGCHLD信号回收子进程

子进程执行结束之后,父进程如果不对其进行回收,子进程就会变为僵尸进程。 父进程可以通过调用wait()函数和waitpid()函数去回收子进程. 由于子进程结束时会发送SIGCHLD信号给父进程,不过此信号的默认动作为忽略,我们可以通过系统函…

【汇编语言】8086汇编语言的debug中,t和p命令的区别

单步跟踪命令(单步进入(step in)):t命令是单步执行,是真的单步执行,碰到任何地方,都会一步步执行,遇到子程序,也会进入里面一步步执行再返回 单步执行命令(单步通过(ste…

哲学家就餐问题(如何避免死锁)(多线程版)

哲学家就餐问题 多线程编程中&#xff0c;常常会遇到线程间访问共享资源的问题&#xff0c;如果处理不当则会发生死锁&#xff0c;某一个线程可能永远访问不到共享资源。 为了避免死锁的发生&#xff0c;提出哲学家就餐问题。 下面展示一些代码片段 #include <stdio.h>…

【汇编语言】汇编语言如何编程,如何避免出错

0 前言 这里以8086汇编语言举例。 1 重要方法&#xff1a;画流程图 这一点不再多说&#xff01;你懂的&#xff01;只要真的画流程图&#xff0c;并且按此翻译为汇编代码&#xff0c;程序出错几率就会减少很多。 2 框架思维&#xff1a;构建标准编程框架 这里只举例说明一…

【汇编语言】8086汇编字符串定义为何使用DB?其他数据类型不可以吗?(20200515复盘)

目录0 前言0.1 先告诉你结论1 8086汇编语言中的字符串1.1 字符串的定义与使用1.2 直接定义的细节1.2.1 使用DB数据类型1.2.2 使用其他数据类型1.3 直接使用的细节1.3.1 赋值给寄存器1.3.2 赋值给内存单元1.3.3 字符串直接使用的本质1.4 应用2 扩展&#xff1a;数据定义的方式3 …

哲学家就餐(避免死锁)(多进程版)

哲学家就餐&#xff08;避免死锁&#xff09;&#xff08;多进程版&#xff09; 哲学家就餐利用信号量在多进程之间实现 下面展示一些代码片段 #include <stdio.h> #include <unistd.h> #include <stdlib.h> #include <sys/wait.h> #include <sys…

【汇编语言】数据类型的匹配问题:自动匹配与手动匹配

0 前言 本文基于8086汇编语言&#xff0c;不过x86系列语言具备向下兼容特点&#xff0c;大多数情况都可以用。 与高级语言数据类型的自动转换和强制转换一样&#xff0c;汇编语言的数据类型也有 自动匹配和手动匹配。 下面&#xff0c;我来介绍一下汇编语言的相关原则。 1 …

生产者消费者模型(条件变量+互斥锁)

生产者消费者模型 线程同步典型的案例即为生产者消费者模型&#xff0c;而借助条件变量来实现这一模型&#xff0c;是比较常见的一种方法。假定有两个线程&#xff0c;一个模拟生产者行为&#xff0c;一个模拟消费者行为。两个线程同时操作一个共享资源&#xff0c;生产者向其…

【汇编语言】王爽实验8,分析一个奇怪的程序,学习笔记(20200517)

0 前言 先给出源程序 assume cs:code code segmentmov ax,4c00hint 21hstart:mov ax,0s:nopnopmov di,offset smov si,offset s2mov ax,cs:[si]mov cs:[di],axs0:jmp short ss1:mov ax,0int 21hmov ax,0s2:jmp short s1nopcode ends end start运行结果&#xff1a;本程序能够…

Qt制作定时关机小程序

文章目录 完成效果图ui界面ui样图 main函数窗口文件头文件cpp文件 引言 一般定时关机采用命令行模式&#xff0c;还需要我们计算在多久后关机&#xff0c;我们可以做一个小程序来定时关机 完成效果图 ui界面 <?xml version"1.0" encoding"UTF-8"?>…

MIPS快速入门(原文+翻译):MIPS Architecture and Assembly Language Overview(持续更新中)

前言 发布该文章的网站已经无法访问&#xff0c;无法获得相关翻译授权&#xff0c;本人的翻译仅供大家参考学习&#xff0c;尽可能使用直译&#xff0c;并加上一些译者注&#xff08;使用“ [1] ”的形式&#xff09;&#xff0c;以减少信息损失&#xff0c;水平有限&#xff…

Visual Studio 编译优化选项:Debug与Release、禁止优化与O1、O2、Ox优化

Debug与禁止优化 Debug模式是调试模式&#xff0c;会有很多冗余的调试代码&#xff0c;供开发者调试程序使用。 VS是默认使用Debug模式的&#xff0c;我使用的是VS 2017。 在Debug模式下&#xff0c;是默认开启禁止优化的&#xff0c;我们来查看一下 在左侧源文件的main.c处…

【汇编语言】记录一组数中负数的个数,8086与MIPS汇编程序

题目及解答 统计由DATA开始的字节数据串中负元素的个数&#xff0c;数据个数在COUNT单元&#xff0c;统计结果存入RLT单元。 8086汇编&#xff1a; ; 统计数字中负数的个数【循环中加了个if else】 assume ds:datasg datasg segmentdata db 1,-2,-3,-1,-4,0,-2 count dw 7 ; 数…

【数字逻辑入门】计算机如何存储1位二进制数

0 前言 本文将会以R-S锁存器为例&#xff0c;引出锁存器的核心和本质&#xff0c;之后再带你构建更多类型的锁存器&#xff0c;你能够&#xff1a; 感受到由浅入深的学习方式体会到掌握核心本质的快感深刻理解核心套外壳的设计理念&#xff08;产品迭代1.0–>2.0–>3.0…

【算法训练】DAY1:整数反转

1 前言 题目来源于Leetcode。 重点&#xff1a;理清逻辑&#xff0c;忽略细节&#xff0c;模仿高手&#xff0c;五毒神掌 2 题目分析 题目很容易理解&#xff0c;先分成两个部分 正数负数 先解决正数 最开始想到的是 intchar数组long唯一增加的就是&#xff0c;先判断整…