简单来说,只要更改一下编码方式就可以了。
代码如下:
public class Main {
public static void main(String[] args) {
// 设置控制台输出编码为UTF-8
System.setOut(new PrintStream(System.out, true, "UTF-8"));
// 输出中文
System.out.println("你好,世界!");
}
}
如果想要了解一下背后的原理,就需要学习一下关于编码规则的知识
在编程语言中,字符串是由字符组成的,而每个字符都对应着一个特定的编码值。对于英文字符,常用的编码方式是ASCII编码,它使用7个比特位来表示128个常见的字符。而对于中文字符,由于中文字符数量较多,单独使用ASCII编码是不够的。因此,为了表示中文字符,需要使用更多的比特位。
在Java中,对于字符编码方式,常用的有Unicode编码。Unicode是一种标准的字符集,它为世界上几乎所有的字符都分配了一个唯一的编码值。Java的字符类型char以及字符串类型String都是基于Unicode编码的。Unicode编码使用16个比特位来表示字符,因此可以容纳更多的字符。
另外,在实际的文本处理中,我们还需要考虑编码的具体实现方式,如UTF-8、UTF-16等。UTF-8是一种变长的Unicode编码方式,使用8位、16位或24位来表示字符。UTF-8编码兼容ASCII编码,可以在一个字节中表示ASCII字符,对于其他字符则使用多个字节进行编码。相比之下,UTF-16是一种固定长度的Unicode编码方式,使用16位编码每个字符。
总结来说,中文和英文在编码方式方面的不同在于所使用的字符集和编码方式。中文需要使用更多的比特位来表示,常用的编码方式是Unicode编码,而具体的实现方式可以是UTF-8或UTF-16等。而英文使用较少的比特位进行表示,常用的编码方式是ASCII编码。