博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
从JDK源码角度看Short
阅读量:6573 次
发布时间:2019-06-24

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

概况

Java的Short类主要的作用就是对基本类型short进行封装,提供了一些处理short类型的方法,比如short到String类型的转换方法或String类型到short类型的转换方法,当然也包含与其他类型之间的转换方法。

继承结构

--java.lang.Object  --java.lang.Number    --java.lang.Short复制代码

主要属性

public static final short   MIN_VALUE = -32768;public static final short   MAX_VALUE = 32767;public static final Class
TYPE = (Class
) Class.getPrimitiveClass("short");public static final int SIZE = 16;public static final int BYTES = SIZE / Byte.SIZE;复制代码
  • MIN_VALUE静态变量表示short能去的最小值,为-32768(-2的15此方),被final修饰说明不可变。
  • 类似的还有MAX_VALUE,表示short最大值为32767(2的15次方减1)。
  • SIZE用来表示二进制补码形式的short值的比特数,值为16,静态变量且不可变。
  • BYTES用来表示二进制补码形式的short值的字节数,值为SIZE除于Byte.SIZE,结果为2。
  • TYPE的toString的值是short
    Class的getPrimitiveClass是一个native方法,在Class.c中有个Java_java_lang_Class_getPrimitiveClass方法与之对应,所以JVM层面会通过JVM_FindPrimitiveClass函数会根据"short"字符串获得jclass,最终到Java层则为Class<Short>
JNIEXPORT jclass JNICALLJava_java_lang_Class_getPrimitiveClass(JNIEnv *env,                                       jclass cls,                                       jstring name){    const char *utfName;    jclass result;    if (name == NULL) {        JNU_ThrowNullPointerException(env, 0);        return NULL;    }    utfName = (*env)->GetStringUTFChars(env, name, 0);    if (utfName == 0)        return NULL;    result = JVM_FindPrimitiveClass(env, utfName);    (*env)->ReleaseStringUTFChars(env, name, utfName);    return result;}复制代码

TYPE执行toString时,逻辑如下,则其实是getName函数决定其值,getName通过native方法getName0从JVM层获取名称,

public String toString() {        return (isInterface() ? "interface " : (isPrimitive() ? "" : "class "))            + getName();    }复制代码

getName0根据一个数组获得对应的名称,JVM根据Java层的Class可得到对应类型的数组下标,比如这里下标为9,则名称为"short"。

const char* type2name_tab[T_CONFLICT+1] = {  NULL, NULL, NULL, NULL,  "boolean",  "char",  "float",  "double",  "byte",  "short",  "int",  "long",  "object",  "array",  "void",  "*address*",  "*narrowoop*",  "*conflict*"};复制代码

主要方法

parseShort方法

public static short parseShort(String s, int radix)        throws NumberFormatException {        int i = Integer.parseInt(s, radix);        if (i < MIN_VALUE || i > MAX_VALUE)            throw new NumberFormatException(                "Value out of range. Value:\"" + s + "\" Radix:" + radix);        return (short)i;}public static short parseShort(String s) throws NumberFormatException {        return parseShort(s, 10);}复制代码

两个parseShort方法,主要看第一个即可,第一个参数是待转换的字符串,第二个参数表示进制数,这里的转换其实是调了Integer的parseInt方法,返回值再判断是不是在short的最小值和最大值之间。怎么更好理解这个参数呢?举个例子,Short.parseShort("100",10)表示十进制的100,所以值为100,而Short.parseShort("100",2)表示二进制的100,所以值为4。另外如果Short.parseShort("100000",10)会抛出java.lang.NumberFormatException异常。

构造函数

public Short(String s) throws NumberFormatException {    this.value = parseShort(s, 10);}public Short(short value) {    this.value = value;}复制代码

包含两种构造函数,分别可以传入short和String类型。它是通过调用parseShort方法进行转换的,所以转换逻辑与上面的parseShort方法一样。

toString方法

public static String toString(short s) {    return Integer.toString((int)s, 10);}public String toString() {   return Integer.toString((int)value);}复制代码

一个是静态方法一个是非静态方法,但两个方法转换的效果是一样的,都是以十进制形式转换。

ShortCache内部类

private static class ShortCache {    private ShortCache(){}    static final Short cache[] = new Short[-(-128) + 127 + 1];    static {        for(int i = 0; i < cache.length; i++)            cache[i] = new Short((short)(i - 128));    }}复制代码

ShortCache是Short的一个内部类,它包含了short可能值的Short数组,范围是[-128,127],它不会像Byte类将所有可能值缓存起来,因为Short类型范围很大,将它们全部缓存起来代价太高,而Byte类型就是从-128到127,一共才256个。所以这里只实例化256个Short对象,当Short的值范围在[-128,127]时则直接从缓存中获取对应的Short对象,不必重新实例化。当然这些缓存值都是静态且final的,避免重复的实例化和回收。

valueOf方法

public static Short valueOf(short s) {    final int offset = 128;    int sAsInt = s;    if (sAsInt >= -128 && sAsInt <= 127) { // must cache        return ShortCache.cache[sAsInt + offset];    }    return new Short(s);}复制代码

有三个valueOf方法,主要看上面这个,因为ShortCache缓存了[-128,127]值的Short对象,对于在范围内的直接从ShortCache的数组中获取对应的Short对象即可,而在范围外的则需要重新实例化了。

decode方法

public static Short decode(String nm) throws NumberFormatException {    int i = Integer.decode(nm);    if (i < MIN_VALUE || i > MAX_VALUE)        throw new NumberFormatException(                "Value " + i + " out of range from input " + nm);    return valueOf((short)i);}复制代码

decode方法主要作用是解码字符串转成Short型,比如Short.decode("11")的结果为11,而Short.decode("0x11")结果为17,因为后面的是十六进制,它会根据实际情况进行解码。

xxxValue方法

包括shortValue、intValue、longValue、byteValue、floatValue和doubleValue等方法,其实就是转换成对应的类型。

hashCode方法

public int hashCode() {    return Short.hashCode(value);}public static int hashCode(short value) {    return (int)value;}复制代码

hashCode方法很简单,就是直接返回int类型的值。

equals方法

public boolean equals(Object obj) {    if (obj instanceof Short) {        return value == ((Short)obj).shortValue();    }    return false;}复制代码

比较是否相同时先判断是不是Short类型再比较值。

compare方法

public static int compare(short x, short y) {    return x - y;}复制代码

通过相减来比较,大于0则说明x大于y。

无符号转换

public static int toUnsignedInt(short x) {    return ((int) x) & 0xffff;}public static long toUnsignedLong(short x) {    return ((long) x) & 0xffffL;}复制代码

包括转成无符号int型和无符号long型。

以下是广告相关阅读

========广告时间========

鄙人的新书《Tomcat内核设计剖析》已经在京东销售了,有需要的朋友可以到 进行预定。感谢各位朋友。

=========================

相关阅读:

欢迎关注:

这里写图片描述

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

你可能感兴趣的文章
python爬虫入门—统计豆瓣电影评论词频
查看>>
【LoadRunner技术讲座4】利用sitescope监测监控mysql
查看>>
转:模态对话框的支持 (IE,Firefox,Chrome)
查看>>
Jenkins+QTP自动化测试框架
查看>>
《Node.js In Action》笔记之流程控制
查看>>
3518EV200 SDK学习1
查看>>
1163: 零起点学算法70——Yes,I can!
查看>>
2018-2019-2 网络对抗技术 20165318 Exp1 PC平台逆向破解
查看>>
关于图片或者文件在数据库的存储方式归纳
查看>>
hihocoder 1014 Trie树
查看>>
ADO.NET笔记——使用DataSet返回数据
查看>>
MOTO XT702添加开机音乐
查看>>
Python脚本日志系统
查看>>
B0BO TFS 安装指南(转载)
查看>>
gulp常用命令
查看>>
TCP(Socket基础编程)
查看>>
RowSet的使用
查看>>
每日一记--cookie
查看>>
WPF and Silverlight 学习笔记(十二):WPF Panel内容模型、Decorator内容模型及其他...
查看>>
MySQL:创建、修改和删除表
查看>>