博客
关于我
一篇文章带你搞懂 Java 中数组长度为 0 和数组为 null 的区别
阅读量:360 次
发布时间:2019-03-04

本文共 460 字,大约阅读时间需要 1 分钟。

编程题中经常遇到,对于数组首先判断:

private static void test(int[] a) {           if (a == null || a.length==0) {               return;        }    }

常见的形式有三种:

语句1:int[] a; //只是声明了一个数组变量,并未初始化,无法使用。语句2:int[] a = null;//声明了一个数组变量,赋值为 null;语句3:int[] a = new int[0];//声明并创建一个数组对象,长度为0

上面的三个语句,系统占用的内存依次增多。

语句1,并未初始化,使用会出错:

在这里插入图片描述

语句2,虽然初始化,但是一个空指针,没有指向一个有效的数组什么都做不了,无法调用这个对象的方法,会产生空指针异常:

在这里插入图片描述

语句3,长度是0,是一个数组对象,只不过没有内容:

在这里插入图片描述


所以对于数组,不但要判断它是否为空指针,也需要判断它是否有内容,同时要先判断空指针再判断长度是否为0,顺序不能颠倒,因为空指针没有length属性

转载地址:http://tsar.baihongyu.com/

你可能感兴趣的文章
MySQL优化配置详解
查看>>
Mysql优化高级篇(全)
查看>>
mysql会员求积分_MySql-统计所有会员的最高前10次的积分和
查看>>
mysql会对联合索性排序优化_MySQL索引优化实战
查看>>
MySQL作为服务端的配置过程与实际案例
查看>>
Mysql使用命令行备份数据
查看>>
MySQL保姆级教程(SQL语法基础篇)从小白到高手的进阶指南,收藏这一篇就够了
查看>>
MySQL修改root密码的各种方法
查看>>
MySQL修改root密码的多种方法
查看>>
mysql修改一列属性
查看>>
MySQL修改密码报错ERROR 1396 (HY000): Operation ALTER USER failed for ‘root‘@‘localhost‘
查看>>
Mysql全局优化参数
查看>>
MySQL全文索引实现简单版搜索引擎
查看>>
MySQL全面瓦解:安装部署与准备
查看>>
mysql共享锁与排他锁
查看>>
MySQL内存表使用技巧
查看>>
MySQL再叙(体系结构、存储引擎、索引、SQL执行过程)
查看>>
mysql出现错误的解决办法
查看>>
MySQL函数
查看>>
mysql函数汇总之字符串函数
查看>>