Character类是一个包装类。

char这种数据类型是基于原始的Unicode编码的,储存一个char用16个bit,因此定义characters也是16位定长的实体集合。

Unicode编码标准发生了变化,数量级从\uFFFF到了\u10FFFF

对Unicode标准中的所有字符,16位已经是不够的了,即一部分字符并不能通过char来表示了。

我们称\u0000 to \uFFFF的字符集合,也就是用一个char能够表示的字符的集合,为the Basic Multilingual Plane (BMP)(基本字符)。

而称码点(code point)大于\uFFFF的字符集合为supplementary characters(补充字符)。

为了解决补充字符表示的问题,首先想到的是基本数据类型int,一个int对象占了32bit,肯定可以表达所有的字符。

但是表示基本字符,只需要16位就够了,表示一个补充字符,也只需要21位,高位的11位都为0,很浪费空间呐!

这个时候可以考虑使用到Character这个包装类了

允许一个Character的对象包装一个或者两个基本类型为char的值,补充字符就拥有了两个基本类型为char的值。

其中,高位的char的取值范围是\uD800--\uDBFF(4*16*16种),低位的char的取值范围是\uDC00--\uDFFF(4*16*16种)。

4*16*16*4*16*16==0x10*16*16*16*16,可以完整表达所有补充字符。

Character有两种构造方法,它接受不同的参数类型。

一种是char,这样自然不能实现补充字符的构造Character

另一种就是int,一个int的范围是0x00000000-0xFFFFFFFF,可以拿任意一个字符的Unicode编码值来作为参数

几个比较难懂,又可能会用到的方法介绍:

1.public static int digit(char ch,int radix)

首先基数radix必须满足在开区间[Character.MIN_RADIX ,Character.MAX_RADIX ]之内,否则直接返回-1;

Character.MIN_RADIX = 2;Character.MAX_RADIX = 36,为什么是2和36呢?

然后ch(ch会被默认转化成Character)也必须是有效的,ch怎样才算有效呢?分以下几种情况:

1.isDigit(ch)==true,也就是new Character(ch).getType(ch)==DECIMAL_DIGIT_NUMBER,也就是可能是一个数字。

数字可以有很多,‘0’--‘9’:

'\u0030' through '\u0039', ISO-LATIN-1 digits ('0' through '9')

'\u0660' through '\u0669', Arabic-Indic digits

'\u06F0' through '\u06F9', Extended Arabic-Indic digits

'\u0966' through '\u096F', Devanagari digits

'\uFF10' through '\uFF19', Fullwidth digits

2.ch是大写字母'A'('\u65')--'Z'('\u90')或者小写字母'a'('\u97')--'z'('\u122')中的一个时,A/a对应是10,依次下去Z/z对应的就是35.

但是同时对应的那个数字不能大于或者等于radix,如果大于或者等于了radix还是返回-1,否则将数字返回

3.ch是全宽大写字母'A'('\uFF21')--'Z'('\uFF3A')或者全宽小写字母'a'('\uFF41')--'z'('\uFF5A')中的一个时,A/a对应是10,依次下去Z/z对应的就是35.

但是同时对应的那个数字不能大于或者等于radix,如果大于或者等于了radix还是返回-1,否则将数字返回

public static int digit(int codePoint,int radix)本质上是一样的,只是char现在已经不能表示所有的字符了,

有些补充字符只用字符的Unicode编码值,用一个int来表示了,所以对应也用用一个int表示一个字符来传参的方法

digit('A',16)和digit(65,16)的结果是一样的。(int)'A'==65

2.public static char forDigit(int digit,int radix)

首先基数radix有效(即在开区间[2,36]内)

然后digit要有效,即0<=digit<radix(好像多少多少进制一样,最高36进制,最低二进制)

0-9分别对应的'0'-'9',10-35分别对应的小写的'a'-'z'

只有当radix和digit同时有效的时候才返回字符,否则返回'\u0000'空字符

3.public static int getNumericValue(char ch)

Returns the int value that the specified Unicode character represents.

返回指定的Unicode字符表示的int值。

For example, the character '\u216C' (the roman numeral fifty) will return an int with a value of 50.

例如,字符'\ u216C'(罗马数字50)将返回一个int 值50。

字符'0'-'9'就返回0-9

字符不管是'A'('\u65')--'Z'('\u90'),'a'('\u97')--'z'('\u122'),还是'A'('\uFF21')--'Z'('\uFF3A'),'a'('\uFF41')--'z'('\uFF5A')

都对应返回的是10-35

public static int getNumericValue(int codePoint)就是对应的用一个int表示一个字符来传参的方法

总结

简单讲其实就是,radix确定基数,确定是多少进制,从0到9,再从a到z(大小写不敏感),分别被视为0到9,10到35

像十六进制一样数字0到9表示了0-9,那9之后的10,11,12,13,14,15怎么表示呢,就把26个字母拿出来用啊。

最少是二进制(MIN_RADIX),最多是三十六(10+26=36)进制(MAX_RADIX)。

int digit(char ch,int radix)

是几进制中某一位上的字符(是数字或者字母)所对应的数字,digit('h',20)==17

char forDigit(int digit,int radix)

是几进制上数字应该用哪个字符(是数字或者字母)表示,forDigit(17,20)=='h'


原文地址:https://blog.csdn.net/lipipifighting/article/details/47321853

关于Character的digit,forDigit,getNumericValue方法的一点理解的更多相关文章

  1. rt-thread中动态内存分配之小内存管理模块方法的一点理解

    @2019-01-18 [小记] rt-thread中动态内存分配之小内存管理模块方法的一点理解 > 内存初始化后的布局示意 lfree指向内存空闲区首地址 /** * @ingroup Sys ...

  2. 对ContentProvider中getType方法的一点理解

    在上篇博客中我们介绍了自定义ContentProvider,但是遗漏掉了一个方法,那就是getType,自定义ContentProvider一般用不上getType方法,但我们还是一起来探究下这个方法 ...

  3. convertView&setTag方法的一点理解

    前言 首先我们要知道setTag方法是干什么的,SDK解释为 Tags Unlike IDs, tags are not used to identify views. Tags are essent ...

  4. VMware安装时Error 1324. The path My Documents contains a invalid character的原因和解决方法

    终于找到了自己想要的答案,顶顶,吼吼~ 我今天安装VMware Workstation时,总是提示我Error 1324. The path My Documents contains a inval ...

  5. SyntaxError: Non-ASCII character '\xe7' in file解决方法

    SyntaxError: Non-ASCII character '\xe7' in file 出现这种错误的原因是程序中的编码出问题了,只要在程序的最前面加上 最前面的意思是在最前面,包括在注释的前 ...

  6. java.util.regex.PatternSyntaxException: Dangling meta character '*' near index 0 *&* 解决方法

    java.util.regex.PatternSyntaxException: Dangling meta character '*' near index 0*&*^    at java. ...

  7. HDU 1061 Rightmost Digit解决问题的方法

    求大量N^N的值最右边的数字,即最低位. 它将能够解决一个简单二分法. 只是要注意溢出,只要把N % 10之后.我不会溢出,代替使用的long long. #include <stdio.h&g ...

  8. Object类clone方法的自我理解

    网上搜帖: clone()是java.lang.Object类的protected方法,实现clone方法: 1)类自身需要实现Cloneable接口 2)需重写clone()方法,最好设置修饰符mo ...

  9. 对Object类中方法的深入理解

    看一下API中关于Object的介绍: 类 Object 是类层次结构的根类.每个类都使用 Object 作为超类.所有对象(包括数组)都实现这个类的方法. 那么Object中到底有哪些方法,各自有什 ...

随机推荐

  1. MaxCompute 构建企业云数据仓库CDW的最佳实践建议

    在本文中阿里云资深产品专家云郎分享了基于阿里云 MaxCompute 构建企业云数据仓库CDW的最佳实践建议. 本文内容根据演讲视频以及PPT整理而成. 大家下午好,我是云郎,之前在甲骨文做企业架构师 ...

  2. Valgrind 初次接触

    Valgrind 英文的意思是:堆内存 它有很多小工具,作用各不相同 学习于: http://blog.csdn.net/sduliulun/article/details/7732906 http: ...

  3. LintCode 斐波纳契数列

    查找斐波纳契数列中第 N 个数. 所谓的斐波纳契数列是指: 前2个数是 0 和 1 . 第 i 个数是第 i-1 个数和第i-2 个数的和. 斐波纳契数列的前10个数字是: 0, 1, 1, 2, 3 ...

  4. 跨域知识(一)——CORS

    CORS是一个W3C标准,全称是"跨域资源共享"(Cross-origin resource sharing). 它允许浏览器向跨源服务器,发出XMLHttpRequest请求,从 ...

  5. BZOJ 1934洛谷2057善意的投票题解

    题目链接 BZ链接 又是一道玄学的网络流题 我们这样建图: 对于同意观点1的原点向其连边,对于同一观点2点向汇点连边 然后如果两个人是朋友,就连一条双向边. 为什么这样是对的呢? 对于一个人来说,他要 ...

  6. 64位linux源码安装mysql

    一:下载mysql http://dev.mysql.com/downloads/mysql/中的Generally Available(GA) Releases标签页,在MySQL Communit ...

  7. 【ToReadList】六种姿势拿下连续子序列最大和问题,附伪代码(以HDU 1003 1231为例)(转载)

    问题描述:       连续子序列最大和,其实就是求一个序列中连续的子序列中元素和最大的那个. 比如例如给定序列: { -2, 11, -4, 13, -5, -2 } 其最大连续子序列为{ 11, ...

  8. Skiing 2017 ACM-ICPC 亚洲区(乌鲁木齐赛区)网络赛H题(拓扑序求有向图最长路)

    参考博客(感谢博主):http://blog.csdn.net/yo_bc/article/details/77917288 题意: 给定一个有向无环图,求该图的最长路. 思路: 由于是有向无环图,所 ...

  9. vue单页面项目返回上一页无效,链接变化了,但是页面没有变化

    在最近的项目中,返回上一页没有效果,经过好久的排查才发现问题,是路由守卫写法不规范导致. 在项目中用路由守卫做了登录拦截,没登录的跳转到登录页面.页面跳转和拦截都没问题,但是返回上一页就不行了,也没有 ...

  10. Oracle基础学习4--Oracle权限传递

    版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/wang379275614/article/details/32215325 以下将用一个实例来解说: ...