包装类及 LeetCode 每日一题
1.包装类与创建对象
Java 为8大数据类型都提供了相应的包装类,并提供属性和方法,更方便的操作基本数据类型。包装类位于java.lang包中。

对于这几种类型的基本数据,都有相似的方法实现基本数据和实例的相互转换:把基本数据类型变量变成包装类实例通过包装类的 valueOf()静态方法;将包装类对象转换成基本类型变量,通过包装类提供的xxxValue()实例方法。要注意类型匹配。
例如 int 类型:
//创建 Integer 对象
Integer i1 = new Integer(10);
Integer i2 = Integer.valueOf(20);
//转换成基本数据
int a = i1.intValue();
而对于 String 类型和基本数据类型的转换,也有特定的方法。
- 用基础类型包装类的 parseXxx(String s)静态方法将字符串转成基本类型变量(除了 Character)。
- 利用基础类型包装类提供的 valueOf(String s)静态方法将字符串转成基本类型变量。
- 用 String 类提供的多个重载的 valueOf()方法将基本类型转换成 String。
事实上从JDK 1.5 之后,Java 对包装类都提供了自动装包和自动拆包,我们完全可以将一个基本类型数据直接赋给一个包装类的变量,或者将一个包装类赋值给一个基本数据类型变量,系统会自动装包成相应的对象或拆包成基本数据。例如:
//自动装箱
Integer i = 10;
//自动拆箱
int n = i;
2 字符串
String 类代表字符串。Java 程序中的所有字符串字面值(如 "abc" )都作为此类的对象。 字符串本质上是一个字符数组,它们的值在创建之后不能更改,所以字符串是常量。可以把字符串看出是字符数组的包装类,内部声明一个private final char value[]。
String a = "abc";
String b = "abc"
//这里输出 true,因为“abc”保存在常量池,两个变量指向同一块内存
System.out.println(a == b);
//这里输出false,因为涉及到变量的运算,系统在运行时才知道结果;若给 a 和 b 加上final,则变成 true
System.out.println(a + b == "abcabc");
字符串的构造方法中,支持使用一个 byte 数组作为参数构造一个字符串,默认采用当前系统默认的编码方式解码该字节数组。例如:
byte[] b1 = {-42,-48};
String s1 = new String(b1);
//这里将会输出一个中文汉字:“中”;windows默认用gbk编码,gbk编码用两个字节编码汉字。
System.out.println(s1);
也可以增加第二个参数,指定解码方式
3 比较
基本数值类型数据可以直接和其包装类进行比较,例如:
Integer num1 = 2;
//输出true
System.out.println(num1 == 2);
但是两个包装类的变量的比较就比较复杂,只有两个变量指向同一实例才返回true。其中也有一些奇怪的现象:
Integer a = 2;
Integer b = 2;
System.out.println(a == b);//输出true
Integer biga = 128;
Integer bigb = 128;
System.out.println(biga == bigb);//输出false
这种现象是因为,系统将-128 - 127 的整数放入了一个名为 cache 的数组中缓存起来, 当将这个范围内的整数自动装箱成一个 Integer 实例时,实际上直接指向对应的数组元素,因此 a 和 b 指向同一个数组元素,它们相等;而这个范围外的,将会新建一个对象,所以不相等。
3.1 compareTo() 和 compare() 方法
所有包装类都提供了 compare(Xxx val1 , Xxx val2) 静态方法,比较两个基本类型值的大小,如果参数1大于参数2,返回 1;相等返回 0;小于返回 -1。包括 boolean 类型都有这个方法(true > false)。
包装类还提供了 compareTo(Xxx val) 实例方法,比较两个实例的大小,大于返回正数,相等返回 0,小于返回负数。
String 类型的 compareTo() 方法会由第一个字符开始逐个比较,a < z,小写大于大写,有大于无,只要有不相同的位就分出大小。
4 LeetCode
66. 加一
给定一个由整数组成的非空数组所表示的非负整数,在该数的基础上加一。最高位数字存放在数组的首位, 数组中每个元素只存储一个数字。你可以假设除了整数 0 之外,这个整数不会以零开头。
示例 1:
输入: [1,2,3]
输出: [1,2,4]
解释: 输入数组表示数字 123。
示例 2:
输入: [4,3,2,1]
输出: [4,3,2,2]
解释: 输入数组表示数字 4321。
第一编提交的时候,忽略了这个字符数组最高位是9,同时发生了进位,需要加一位的情况。最终答案如下:
class Solution {
public int[] plusOne(int[] digits) {
int count = 1;
for(int i = digits.length - 1; i >= 0; i--){
digits[i] += count;
if(digits[i] == 10){
digits[i] = 0;
count = 1;
if(i == 0){
int[] tmp = new int[digits.length + 1];
System.arraycopy(digits, 0, tmp, 1,digits.length);
tmp[0] = count;
digits = tmp;
}
}else {
count = 0;
//也可以直接 break;
}
}
return digits;
}
}
包装类及 LeetCode 每日一题的更多相关文章
- 【js】Leetcode每日一题-制作m束花所需的最少天数
[js]Leetcode每日一题-制作m束花所需的最少天数 [题目描述] 给你一个整数数组 bloomDay,以及两个整数 m 和 k . 现需要制作 m 束花.制作花束时,需要使用花园中 相邻的 k ...
- 【JavaScript】Leetcode每日一题-在D天内送包裹的能力
[JavaScript]Leetcode每日一题-在D天内送包裹的能力 [题目描述] 传送带上的包裹必须在 D 天内从一个港口运送到另一个港口. 传送带上的第 i 个包裹的重量为 weights[i] ...
- 【js】Leetcode每日一题-完成所有工作的最短时间
[js]Leetcode每日一题-完成所有工作的最短时间 [题目描述] 给你一个整数数组 jobs ,其中 jobs[i] 是完成第 i 项工作要花费的时间. 请你将这些工作分配给 k 位工人.所有工 ...
- 【js】Leetcode每日一题-数组异或操作
[js]Leetcode每日一题-数组异或操作 [题目描述] 给你两个整数,n 和 start . 数组 nums 定义为:nums[i] = start + 2*i(下标从 0 开始)且 n == ...
- 【js】Leetcode每日一题-解码异或后数组
[js]Leetcode每日一题-解码异或后数组 [题目描述] 未知 整数数组 arr 由 n 个非负整数组成. 经编码后变为长度为 n - 1 的另一个整数数组 encoded ,其中 encode ...
- 【JavaScript】Leetcode每日一题-青蛙过河
[JavaScript]Leetcode每日一题-青蛙过河 [题目描述] 一只青蛙想要过河. 假定河流被等分为若干个单元格,并且在每一个单元格内都有可能放有一块石子(也有可能没有). 青蛙可以跳上石子 ...
- 【JavaScript】Leetcode每日一题-平方数之和
[JavaScript]Leetcode每日一题-平方数之和 [题目描述] 给定一个非负整数 c ,你要判断是否存在两个整数 a 和 b,使得 a2 + b2 = c . 示例1: 输入:c = 5 ...
- 【JavaScript】Leetcode每日一题-二叉搜索树的范围和
[JavaScript]Leetcode每日一题-二叉搜索树的范围和 [题目描述] 给定二叉搜索树的根结点 root,返回值位于范围 [low, high] 之间的所有结点的值的和. 示例1: 输入: ...
- 【JavaScript】Leetcode每日一题-递增顺序搜索树
[JavaScript]Leetcode每日一题-递增顺序搜索树 [题目描述] 给你一棵二叉搜索树,请你 按中序遍历 将其重新排列为一棵递增顺序搜索树,使树中最左边的节点成为树的根节点,并且每个节点没 ...
随机推荐
- struts升级2.3.12到2.5.13
参考文章: http://www.ituring.com.cn/article/495914 http://blog.csdn.net/zhangchen1987/article/details/78 ...
- js算法初窥01(排序算法01-冒泡、选择、插入)
排序,我想大家一定经历过或者正在经历着.或许你不懂算法,对排序算法一无所知,但是你一定用过一些第三方库的api来一键排序,那么,在你享受便捷的同时,你是否想过它的底层是如何实现的?这样的算法实现方式是 ...
- python3+requests:使用类封装接口测试脚本
前言:接口测试用例较多,我们不可能每个用例都写一次requests,get或者requests,post等,所以对共用方法要进行封装处理 第一次修改:将get请求和post请求单独定义出来,使用过程中 ...
- Lucene入门简介
一 Lucene产生的背景 数据库中的搜索很容易实现,通常都是使用sql语句进行查询,而且能很快的得到查询结果. 为什么数据库搜索很容易? 因为数据库中的数据存储是有规律的,有行有列而且数据格式.数 ...
- java并发之CyclicBarrier
一.CyclicBarrier简述 一个同步辅助类,它允许一组线程互相等待,直到到达某个公共屏障点 (common barrier point).在涉及一组固定大小的线程的程序中,这些线程必须不时地互 ...
- capwap学习笔记——初识capwap(三)(下)
2.5.6.25 Image Data to Reset WTP下载image后重启,重新设置DTLS连接 ¢ WTP: ü 当image的下载完成,或者ImageDataStartTimer定 ...
- 【转】拍拍网2015年mysql最新开发规范
1.命名规范 (1)库名.表名.字段名必须使用小写字母,并采用下划线分割. (2)库名.表名.字段名禁止超过32个字符. (3)库名.表名.字段名必须见名知意.命名与业务.产品线等相关联. (4)库名 ...
- ZooKeeper的使用---命令端
一.进入命令行 ./bin/zkCli.sh 二.常用命令 命令 作用 范例 备注 connect host:port 连接其他zookeeper客户端 connect hadoop2:21 ...
- 使用WampServer和DVWA在Windows10上搭建渗透测试环境
前言: DVWA是一个具有脆弱性的Web测试应用,需要PHP和MySQL的环境支持.我们可以手动配置DVWA所需的运行环境,也可以使用WampServer进行搭建.WampServer是集成了Apac ...
- 常见性能优化策略的总结 good
阅读目录 代码 数据库 缓存 异步 NoSQL JVM调优 多线程与分布式 度量系统(监控.报警.服务依赖管理) 案例一:商家与控制区关系的刷新job 案例二:POI缓存设计与实现 案例三:业务运营后 ...