当前位置: 首页 > 知识库问答 >
问题:

当我分配char(从文字或其他方式)时,这里的“Java内部编码是UTF16”是什么意思?它以什么编码存储在char中?

汝臻
2023-03-14
//non-utf source file encoding
char ch = 'ё'; // some number within 0..65535 is stored in char. 
System.out.println(ch); // the same number output to 

所以这个“内部使用的UTF16编码”从来没有使用过???char只存储任意数字(在[0..65535]中),除了特定的范围之外,“无符号”与int(当然在我的示例的范围内)没有区别???

附言。实验上,用UTF-8编码的源文件和控制台输出编写上面的代码

й
1081

源文件采用win-1251编码,控制台输出采用UTF-8编码

�
65533
String s = "й";
System.out.println(s);

所以研究没有直接回答我的问题:

  • 用什么编码存储Java字符?
  • 键入字符时使用什么编码?
  • 字符对象对应于哪个字符编码(Unicode版本)集?

共有1个答案

井礼骞
2023-03-14

在大多数情况下,最好将char看作某个字符(独立于任何编码),例如字符'a',而不是某些编码中的16位值。只有在charstring与字节序列之间进行转换时,编码才起作用。

char在内部编码为UTF-16,这一事实只有在必须处理它的数值时才很重要。

代理项对仅在字符序列中有意义。单个字符不能保存BMP之外的字符值。这就是字符抽象分解的地方。

 类似资料:
  • 问题内容: 最近,在进行程序时,我遇到了一个问题。以下是程序的一部分 我不明白这行代码的作用: 我猜想它正在递增lettercounts数组中特定字符的值(最初为0);我猜’a’的索引是0,’z’的索引是25。但是我想了解那小段代码是如何工作的。 问题答案: 目的是计算每个字符的出现次数。 是一种获取字符在字母表中位置的巧妙方法。会给你0。会给你1。会给你2,依此类推。 该值用作数组的索引(如您正

  • 问题内容: 我正在用Java做一些String算法,我注意到无论我在哪里包含一个值为0(零)的char,它都标志着String的结尾。像这样: 这种行为的原因/原因是什么? 问题答案: 该字符为空字符。这是一个控制字符,它 不会 终止字符串,这也不是字符串在Java中的工作方式(不过,字符串也是在C中的工作方式。)

  • 问题内容: 说“ Java修改的UTF-8编码”是什么意思?与普通的UTF-8编码有何不同? 问题答案: 这在以下内容的javadoc中进行了详细说明: 修改后的UTF-8 和接口的实现以略微修改UTF-8的格式表示Unicode字符串。(有关标准UTF-8格式的信息,请参见 Unicode标准版本4.0的3.9 Unicode编码形式 )。请注意,在下表中,最高有效位出现在最左侧的列中。 …(某

  • b & 0xFF for b in这个怎么理解

  • 问题内容: 我是Go的新手,在浏览其他一些线程时遇到了以下代码行: 含义是什么?它是否指定将在if条件中分配某些内容(因为err似乎正在发生这种情况)?我在Wiki上找不到这种语法的示例,并且我很好奇它的用途。 问题答案: 因为返回两个值,所以如果需要它们中的任何一个,都必须在某个地方接收这些值。该是一个占位符,基本的意思是“我不关心这个特殊的返回值。” 在这里,我们只关心检查错误,而无需对实际的

  • 问题内容: 这段代码使我凝视了几分钟: 我以前从未见过,而且我也不知道Java有一个“ loop”关键字(NetBeans甚至没有像关键字一样给它上色),并且它在JDK 6中可以很好地编译。 有什么解释? 问题答案: 这不是一个。 用法: