Java数组有哪些用法

Python013

Java数组有哪些用法,第1张

数组:是一组相关变量的集合数组是一组相关数据的集合,一个数组实际上就是一连串的变量,数组按照使用可以分为一维数组、二维数组、多维数组

数据的有点不使用数组定义100个整形变量:int i1int i2int i3

使用数组定义 int i[100]

数组定义:int i[100]只是一个伪代码,只是表示含义的(1)一维数组

一维数组可以存放上千万个数据,并且这些数据的类型是完全相同的,使用java数组,必须经过两个步骤,声明数组和分配内存给该数组,声明形式一声明一维数组:数据类型 数组名[]=null非配内存给数组:数组名=new 数据类型[长度]声明形式二声明一维数组:数据类型 [] 数组名=null

(2)java数据类型分为两大类1.基本数据类型int、long操作的时候本身就是具体的内容引用数据类型:数组、类、接口

引用传递的就是一个内存的使用权,一块内存空间,可能有多个人同时使用

2.事例声明数组

数组的声明格式里,数据类型是数组元素的数据类型,常见的有整形、浮点型、与字符型等数组名是用来统一这组相同数据类型元素的名称,其命名规则和变量的相同数组声明后实际上是在栈内存中保存了此数组的名称,结下了是要在堆内存中配置数组所需要的内存,齐产固定是告诉编译器,所声明的数组要存放多少个元素,而new 则是命令编译器根据括号里的长度。

基本数据类型偶读有其默认值:int 0只要是引用数据类型默认值就是null事例

声明数组的同时分配内存空间声明数组的同时非配内存数据类型 数组名[]=new 数据类型[个数]int score[]=new int[10]声明一个元素个数为10的整形数组score,同时开辟依靠内存空间工期使用java中,由于整形数据类型占用的空间为4个byte,而整个数组score可保存的元素有10个。所以上例中占用的内存共有4*10=40个字节

(3)数组的访问

数组中元素的表示方法想要访问数组里的元素可以利用索引来完成,java的数组索引标号由10开始,以一个score[10]的整形数组为例,score[0]代表第一个元素一直向下,最后一个为score[9]

(4)取得数组的长度在java中取得数组的长度(也就是数组元素的长度)可以利用数组名称.length完成,数组名称.length--返回一个int类型的数据

(5)数组的静态初始化之前的数组,所采用的都是动态初始化,所有的内容在数组声明的时候并不具体的指定,而是以默认值的形式出现静态初始化是指在数组声明后直接为数组指定具体的内容如果想要直接在声明的时候给数组赋初始值,可以采用大括号完成,只要在数组的生命格式后面加上初值的赋值即可,数据类型 数组名 []={初始值0,初始值1,初始值3,....初始值n}

范例排序,在操作中排序是比较常用的从大到小

这个时候不要被i值所迷惑   if(score[i]>score[j]){

这一步主要知识为了比较,实际上完成之后输出的时候是根据j的值排序的

(6)二维数组

二维数组声明的方式和以为数组的类似,内存分配也一样是用new这个关键字

其实声明与分配内存的格式如下动态初始化数据类型 数组名[][]数组名=new 数据类型[行的个数][列的个数]

声明并初始化数组数据类型 数组名[][]=new 数据类型[行的个数][列的个数]静态初始化

(7)二维数组的存储声明二维数组score 同时开辟一段内存空间int score[][]=new int[4][3]整体数据score可保存的元素是4*3=12个,在java中,int数据类型所占用的空间为4个字节,因此该整形数组占用的内存共为4*12=48个字节事例

(8)二维数组静态初始化

用到的时候才会开辟空间,不用的(红色部分)则不开辟空间多维数组一般只是用到二维数组三维数组简单了解

public class a{

    public static void main(String[] args){

        //方法一

        int a[]//声明一个名字为a的整形数组

        a=new int[3]//为名字为a的整形数组创建3个整数的存储空间

        a[0]=2//为名字为a的整形数组中0角标的整数赋值为2

        a[1]=5//为名字为a的整形数组中1角标的整数赋值为5

        a[2]=7//为名字为a的整形数组中2角标的整数赋值为7

        //方法二

        int b[]=new int[3]//声明一个名字为b的整形数组并同时为这个整形数组创建3个整数的存储空间

        b[0]=2//为名字为b的整形数组中0角标的整数赋值为2

        b[1]=5//为名字为b的整形数组中1角标的整数赋值为5

        b[2]=7//为名字为b的整形数组中2角标的整数赋值为7

        //方法三

        int c[]={2,5,7}//声明一个名字为c的整形数组并同时为这个整形数组创建3个整数的存储空间并把0角标的整数值赋值为2,把1角标的整数值赋值为5,把2角标的整数值赋值为7

        //方法四

        int d[]=new int[]{2,5,7}//声明一个名字为d的整形数组并同时为这个整形数组创建3个整数的存储空间并把0角标的整数值赋值为2,把1角标的整数值赋值为5,把2角标的整数值赋值为7

        //注意:以上方法的结果一致,只是数组名字不同

    }

}

1. Nested-Loop Join 翻译过来就是嵌套循环连接,简称 NLJ。

这种是 MySQL 里最简单、最容易理解的表关联算法。

比如,拿语句 select * from p1 join p2 using(r1) 来说,

先从表 p1 里拿出来一条记录 ROW1,完了再用 ROW1 遍历表 p2 里的每一条记录,并且字段 r1 来做匹配是否相同,以便输出;再次循环刚才的过程,直到两表的记录数对比完成为止。

2. Block Nested-Loop Join ,块嵌套循环,简称 BNLJ

那 BNLJ 比 NLJ 来说,中间多了一块 BUFFER 来缓存外表的对应记录从而减少了外表的循环次数,也就减少了内表的匹配次数。还是那上面的例子来说,假设 join_buffer_size 刚好能容纳外表的对应 JOIN KEY 记录,那对表 p2 匹配次数就由 1000 次减少到 1 次,性能直接提升了 1000 倍。

3. 最近 MySQL 8.0.18 发布,终于推出了新的 JOIN 算法 — HASH JOIN。

MySQL 的 HASH JOIN 也是用了 JOIN BUFFER 来做缓存,但是和 BNLJ 不同的是,它在 JOIN BUFFER 中以外表为基础建立一张哈希表,内表通过哈希算法来跟哈希表进行匹配,hash join 也就是进一步减少内表的匹配次数。当然官方并没有说明详细的算法描述,以上仅代表个人臆想。那还是针对以上的 SQL,我们来看下执行计划。