Java数组(int为例)

定义:相同数据类型的数据的组合,是一种引用类型,是一个对象,存在堆里。

数组初始化:int[] scores1 = new int[]{72,90,59};//静态初始化:在声明并初始化数组与给数组相应的元素赋值操作同时进行。

int scores2[] = new int[3];

    scores2[0] = 72;

scores2[1] = 90;

scores2[2] = 59;

//动态初始化:在声明并初始化数组与给数组相应的元素赋值操作分开进行。

//声明数组的错误写法:

1)String[] names = new String[5]{"AA","BB","CC"};

2)int i[10];

3)int i = new int[];

注:不管是动态还是静态初始化数组,一定在创建的时候,就指明了数组的长度!

引用数组元素:通过数组的下角标引用。下角标从0开始,到n-1结束,n是数组的长度。

数组长度:通过.length调用

遍历数组:

for( int i = 0 ; i < scores.length ; I ++){

System.out.println( scores[i]);

   }

数组元素的默认初始值:

byte short int long 初始值为0

float double 初始值为0.0

char 初始值为 空格

boolean 初始值为false

引用类型初始值为null

一维数组的写法:int[] arrs = new int[5];

arrs[0] = 5;

//int arrs[] = new int[5];

二维数组的写法:int [][] is = new int[3][];

        int[][] is2 = {{1,2},{3,4},{5,6}};

数组常见异常:

  1. 数组下标越界异常:java.lang.ArrayIndexOutBoundsException

        int[] i = new int[10];

        i[0] = 0;

        i[10] = 10;//超出数组下标值(下标值越界)

        for( int j = 0 ; j < i.length ; j++){

            System.out.println(i[j]);

        }

2.空指针异常: NullPointerException

  (1) boolean[] b =new boolean[3];

     b = null;

     System.out.println(b[0]);

(2)  String[] str = new String[4];

str[3] = new String("AA");//str[3] = "AA";

System.out.println(str[3].toString());

   (3) int[][] j = new int[3][];

    j[2][0] = 12;

Arrays类:

binayeSearch: 二分搜索法,使用二进制搜索算法来搜索指定类型数组,以获得指定的值。

 输出结果

输出结果为搜索内容在数组中的位置(从0开始)

输出结果

   负数指的是该数应在该数组中的位置(从1开始)

Equals:用于比较两个相同类型的值,如果两个指定类型的值相等则返回true,否则返回false。

Fill:用于填充数组

    

将int[] arrs2 中的内容替换成3

输出结果

将int[] arrs2 中的第二位到第三位替换为9

**2指第二位,4指第四位,9为替换的内容

**2,4指从第二到第三位,而不是从第二位到第四位

输出结果

Sort:对数组中的内容进行排序(从0开始)

public static void sort(int[] a)

copyOf:向数组添加内容

输出结果

copyOfRange: 截取数组内容

截取第0到第3位内容

输出结果

Java数组(int为例)的更多相关文章

  1. 1.1使用java数组,并开始封装我们自己的数组

    今天感冒了,全身酸软无力,啥样不想做,就来学习吧,此节我们从初步使用java中提供的数组,然后分析相关情况,过渡到封装我们自己的数组. 一.我们先来感受一下java提供的数组,以整型数组(int[]) ...

  2. Android java传递int类型数组给C

    接着前面的文章<Android java传递int类型数据给C><Android java传递string类型数据给C>,继续实践 实现public native int[] ...

  3. 第5章 Java数组

    1.什么是数组 数组可以想象成一个巨大的盒子,这个盒子里面存放的是同一个数据类型的数据 例如:int[] scores = {78,68,94,93}; 2.如何使用Java中的数组 2.1申明数组 ...

  4. Java 数组声明与初始化

    引言 学习了好久的java,每次要写数组的声明和初始化代码,总是理不清.最近又碰到了一次这种情况.这次拿出<Thinking In Java>好好总结一翻. 数组声明 对于数组的声明其实都 ...

  5. Java数组的声明和遍历

    Java 数组 数组对于每一门编程语言来说都是重要的数据结构之一,当然不同语言对数组的实现及处理也不尽相同. Java 语言中提供的数组是用来存储固定大小的同类型元素. 你可以声明一个数组变量,如 n ...

  6. java数组集合元素的查找

    java数组和集合的元素查找类似,下面以集合为例. 数组集合元素查找分为两类: 基本查找: 二分折半查找: 基本查找: 两种方式都是for循环来判断,一种通过索引值来判断,一种通过数组索引判断. 索引 ...

  7. Java 数组声明的几种方式

    Java数组定义声明的几种方法: 1. 类型名称[] 变量名=new 类型名称[length]; 2.类型名称[] 变量名={?,?,?}; 3.类型名称[] 变量名=new 类型名称[]{?,?,? ...

  8. 有关JVM处理Java数组方法的思考

    在Java中,获取数组的长度和String的长度是两种不同的方法,这引起了本文作者的一番思考.本文从JVM的角度,探讨了Java数组在JVM中是什么对象,有哪些成员,以及声明方法. 作者:jarfie ...

  9. 七、java数组

    目录 一.一维数组 声明方式 数组对象的创建 元素为引用数据类型的数组 数组初始化 数组元素默认初始化 数组元素的引用 二.二维数组 概念 初始化 二维数组举例 三.数组的拷贝 四.练习 数组可以堪称 ...

随机推荐

  1. 51Nod 1009 数字1的个数 | 数位DP

    题意: 小于等于n的所有数中1的出现次数 分析: 数位DP 预处理dp[i][j]存 从1~以j开头的i位数中有几个1,那么转移方程为: if(j == 1) dp[i][j] = dp[i-1][9 ...

  2. [Luogu 3958] NOIP2017 D2T1 奶酪

    题目链接 人生第一篇题解,多多关照吧. 注意事项: 1.多组数据,每次要先初始化. 2.因为涉及到开根,所以记得开double. 整体思路: 建图,判断「起点」与「终点」是否连通. 方法可选择搜索(我 ...

  3. HDFS不存在绝对路径,无法找到文件所在具体位置

    This is set in the dfs.datanode.data.dir property, which defaults to file://${hadoop.tmp.dir}/dfs/da ...

  4. 判定对象是否存活的算法----GC_ROOT算法

    要应用GC_ROOT算法,判定某个对象是否会被回收,关键是要确定root.确定root之后,你就可以根据代码绘制可达链,从而就可以进行分析了,分析哪些对象会被泄漏,哪些对象会被回收,如果GC执行的时候 ...

  5. 【POJ】1830 开关问题(高斯消元)

    http://poj.org/problem?id=1830 高斯消元无解的条件:当存在非法的左式=0而右式不等于0的情况,即为非法.这个可以在消元后,对没有使用过的方程验证是否右式不等于0(此时因为 ...

  6. 超详细的Java面试题总结(三)之Java集合篇常见问题

    List,Set,Map三者的区别及总结 List:对付顺序的好帮手 List接口存储一组不唯一(可以有多个元素引用相同的对象),有序的对象 Set:注重独一无二的性质 不允许重复的集合.不会有多个元 ...

  7. NodeJS中Buffer模块详解

    一,开篇分析 所谓缓冲区Buffer,就是 "临时存贮区" 的意思,是暂时存放输入输出数据的一段内存. JS语言自身只有字符串数据类型,没有二进制数据类型,因此NodeJS提供了一 ...

  8. js 数组&字符串 去重

    Array.prototype.unique1 = function() { var n = []; //一个新的临时数组 for(var i = 0; i < this.length; i++ ...

  9. 计算机网络课设之基于UDP协议的简易聊天机器人

    前言:2017年6月份计算机网络的课设任务,在同学的帮助和自学下基本搞懂了,基于UDP协议的基本聊天的实现方法.实现起来很简单,原理也很简单,主要是由于老师必须要求使用C语言来写,所以特别麻烦,而且C ...

  10. POJ1014(多重背包)

    Dividing Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 65044   Accepted: 16884 Descri ...