博客
关于我
一篇文章带你搞懂 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 事务知识点与优化建议
查看>>
Mysql 优化 or
查看>>
mysql 优化器 key_mysql – 选择*和查询优化器
查看>>
MySQL 优化:Explain 执行计划详解
查看>>
Mysql 会导致锁表的语法
查看>>
mysql 使用sql文件恢复数据库
查看>>
mysql 修改默认字符集为utf8
查看>>
Mysql 共享锁
查看>>
MySQL 内核深度优化
查看>>
mysql 内连接、自然连接、外连接的区别
查看>>
mysql 写入慢优化
查看>>
mysql 分组统计SQL语句
查看>>
Mysql 分页
查看>>
Mysql 分页语句 Limit原理
查看>>
MySql 创建函数 Error Code : 1418
查看>>
MySQL 创建新用户及授予权限的完整流程
查看>>
mysql 创建表,不能包含关键字values 以及 表id自增问题
查看>>