Ubuntu下NetBeans中文乱码及方框问题的解决方法
当我在ubuntu 11.04中安装netbeans 7.0的时候,出现一个奇怪的现象,启动netbeans中,发现很多中文字无法显示,直接显示一个方框。很显然是没有找到某些字的显示数据,但是奇怪的是有些汉字可以显示,真神奇,难道netbeans所用到的字库居然不全吗?
而 ubuntu可以正常显示汉字,说明ubuntu本身的字库应该是没问题到。那么问题出在什么地方呢?
答案是:JRE
netbean是用java写的,它的运行是必须要依靠JRE的,这个大家都知道。而JRE使用的字体是依靠JRE本身的配置文件来决定在系统中和什么字体文件对应的。
因此判定是这种对应出了问题。
根据Java的官方文档(http://download.oracle.com/javase/1.5.0/docs/guide/intl/fontconfig.html#loading),字体对应配置文件是位于jre/lib下面,有两种形式,一种是src文件,一种是bfc文件。bfc文件是二进制的,系统预定义的,所以我们需要修改的是src文件,到这个目录,一看,如下图:

看到这些文件名,基本也明白了个大概。看看fontconfig.OS.version.properties.src这种格式就应该明白,这是不同操作系统平台的配置文件,jre会根据操作系统的不同而自动选择对应的配置文件,因此,我打开了ubuntu 的对应文件,看第一行:
allfonts.chinese-cn-iso10646=-arphic-ar pl uming cn-light-r-normal--*-%d-*-*-c-*-iso10646-1
这里指定了jre用到逻辑字体和物理字体的对应关系,等号左边就是jre用的逻辑字体,而等号右边就是需要使用的物理字体了。
只是这个物理字体看起来跟火星文差不多,但是这个火星文可是正宗的X logical font description (XLFD)描述方式,这里不多说了,想了解的读者可以自己去google一下即可。
然后再看配置文件# Font File Names部分,其中有一行:
filename.-arphic-ar_pl_uming_cn-light-r-normal--*-%d-*-*-c-*-iso10646-1=/usr/share/fonts/truetype/arphic/uming.ttc
这是上面描述的物理字体和系统字体文件的对应描述。
左边不就是上面我们看着像火星文的物理字体名称吗?正好不知道哪儿去找这个字体,这下不就有答案了。连目录都告诉你了。
立刻跑到/usr/share/fonts/truetype目录去一看,不要说uming.ttc,连arphic这个目录都没有!
这下就面临两个选择:
1.修改配置文件,让他指向系统有的字体文件。
也就是修改:/usr/share/fonts/truetype/arphic/uming.ttc这部分,修改成存在的字体文件名称即可。
2.安装一个uming.tcc字体文件。
由于uming.tcc字体是比较有名的,是一个高质量的中文字库。因此我还是决定选择第二种方案。
到网上一goole,立刻找到了下载地址:http://ftp.br.debian.org/debian/pool/main/t/ttf-arphic-uming/ttf-arphic-uming_0.2.20080216.1-3_all.deb
下载回来之后:sudo dpkg -i ttf-arphic-uming_0.2.20080216.1-3_all.deb
安装顺利完成,这个时候再跑到/usr/share/fonts/truetype目录去一看,这下有arphic这个目录了,然后打开目录一看,uming.ttc就在那里!
马上打开netbeans,漫长的等待,终于看到了窗口,一切都有了,字体看着确实很美,不愧是arphic 产品啊。
自此问题完美的解决了,不管版本如何变化,都可以按照这个方式去解决问题。
网上一些文章说的cp字体到jre/lib/fonts/fallback,很多人不懂原理。fallback的目录是jre字体后备目录,意思就是按照正常配置找不到字体信息,就会在这个目录下按照配置文件设定的顺序到字体文件中去寻找。用这个方式有两个问题,一个是效率低下。二是字体不统一,会出现例如:文件这个词,文是楷体,件是黑体的“壮观”景象!为什么?因为文字在楷体字库找到了,但是这个字库找不到件字,于是就在fallback中到黑体字库去找,并且找到。这种现象就神奇的出现了!
所以这个方式其实是属于歪打正着的方法,很多人糊里糊涂显示正常了,也没有搞懂原理。而另外一些人就会出现字体不统一到情况。
当然,上面所说的一切,在windows上均不会发生。因为windows比较统一,所以配置文件的配置一定可以正常工作,不会出现类似linux的连字体文件都可能找不到的情况。这也证明了规范,统一在软件中的重要性。
相关文章

Ubuntu 26.04 LTS(Resolute Raccoon)发布:内存要求提至6GB
2026-04-23,Ubuntu 26.04 LTS 正式版按计划如期发布,Ubuntu 26.04 LTS 搭载 Linux 内核 7.0 和 GNOME 50 桌面环境,原生集成英伟达 CUDA,内存要求提至 6GB2026-04-24
桌面生产力直接拉满! Ubuntu安装后别急着用这7个设置一定要改
Ubuntu桌面系统安装成功后,不要急着使用,修改后桌面生产力直接拉满,今天我就把这7个我每次必改的设置完整分享出来,配上详细步骤和实际效果2026-04-15
CPU和硬盘要求保持不变! Ubuntu 26.04 LTS最低内存运行要求提高到 6GB
Canonical即将发布“Resolute Raccoon”Ubuntu 26.04 LTS操作系统,资料显示推荐内存提高至6GB,这是2018年以来首次重大变动2026-04-08
基于Linux7.0+GNOME50+Mesa26.0! Ubuntu 26.04 LTS Beta 版发布
Ubuntu 26.04 LTS测试版如期发布,此次更新将集成大量前沿开源技术,Beta 测试版搭载了尚处于开发阶段的 Linux 7.0 内核、默认采用最新的 GNOME 50.0 桌面组件、全新的 Mes2026-03-27
近日,全球知名网络安全研究机构Qualys的威胁研究部门正式披露了Ubuntu桌面系统的一个高危本地提权漏洞,其官方漏洞编号为CVE-2026-38882026-03-21
Ubuntu 25.10 系统正式发布:搭载 Linux 6.17 内核
Ubuntu 25.10 系统代号“Questing Quokka”现已推出,集成最新的 GNOME 49 桌面环境,默认仅启用 Wayland 会话,提升了图形体验2025-10-10
Debian 13升级后网络转发等功能异常怎么办? 并非错误而是管理机制变更
很多朋友反馈,更新到Debian 13后网络转发等功能异常,这并非 BUG 而是 Debian 13 Trixie 调整了管理机制,具体来说是sysctl变更为由systemd-sysctl主导且配置文件变成模块2025-08-22
SSH中断/宝塔面板异常/分区问题等! Debian 13升级注意事项汇总
前一段时间发布了debian13,我们也分享了debian12升级到debian13的图文教程,很多朋友在升级的时候遇到了不少问题,今天我们就来看看Debian 13升级注意事项2025-08-21
Debian12怎么升级到Debian13? Debian系统升级教程
心念念的Debian13终于正式发布了,该怎么升级呢?下面我们就来看看Debian12升级到 Debian13的教程2025-08-21
Ubuntu 24.04.3 LTS 正式发布: 附更新内容汇总
Ubuntu 24.04 这一长期支持版本发布了第三个点版本升级:Ubuntu 24.04.3 LTS,涵盖桌面、服务器与云等版本,主要是将过去数月发布的安全更新、错误修复和稳定性改进整合入2025-08-09



最新评论