在解决jni调用出现mp3 tag乱码中的要点:setlocale

上篇说:


若ASCII码直接转换:

result=(env)->NewStringUTF(str );

若含有中文字符:
int length =mbstowcs(wchar_t *wcstr,const char *mbstr,size_t count);

这个函数的第三个参数count,大小一定要是mbstr长度的2倍,否则出来的中文也会是乱码


mbstowcs的使用是需要正确设置locale的。简简单单写setlocale(LC_ALL,"");是否可以使当前语言环境支持所有编码的字符呢?


linux下一般的 locale "zh_CN.UTF-8"


UTF-8 是编码,en_US.UTF-8、zh_CN.UTF-8叫做字符集,就是说‘A’、‘B’、‘中’、‘国’等对应的整数值,en_US 和 zh_CN 也是语言环境
en_US.UTF-8 和 zh_CN.UTF-8 包含的字符数量是基本上一样的,大概是七万个汉字,编码都是 UTF-8 编码,字符集是 Unicode,zh_CN.GB18030 和 zh_CN.GBK 的字符集都与 Unicode 3 是等价的
语言环境的差别就是另一回事了,中国人和外国人表示时间啦,数字啦,习惯都不一样,所以必须区分开。

大部分程序根据语言环境变量来选择界面的语言是中文还是英文。

下面是console上的一些输出 > > > > > >
我查看已经安装的语言包:
# locale -a


查看当前的设置:
# locale


修改设置:
# export LC_ALL=ZH_CN.UTF-8


你可能感兴趣的:(locale)