Eclipse MAT和Heaphero都是分析大型堆转储的流行Java工具。 最近,当我们尝试在Eclipse MAT中分析堆转储文件时遇到了一个有趣的问题。 工具因缺少字体crash而崩溃。 我们认为我们将与您分享发现的结果。
CompositeStrike.getStrikeForSlot()中的ArrayIndexOutOfBoundsException
这是我们的环境:
- Eclipse MAT 1.9
- Java 8
- Linux 3.10.0-862.34.2.el7.x86_64
当我们将堆转储文件上传到Eclipse MAT时,它失败并出现以下错误:
java.lang.ArrayIndexOutOfBoundsException: 0
at sun.font.CompositeStrike.getStrikeForSlot(CompositeStrike.java:75)
at sun.font.CompositeStrike.getFontMetrics(CompositeStrike.java:93
at sun.font.FontDesignMetrics.initMatrixAndMetrics(FontDesignMetrics.java:359)
at sun.font.FontDesignMetrics.<init>(FontDesignMetrics.java:350)
at sun.font.FontDesignMetrics.getMetrics(FontDesignMetrics.java:302)
at sun.java2d.SunGraphics2D.getFontMetrics(SunGraphics2D.java:863)
at org.eclipse.birt.chart.device.swing.SwingTextMetrics.reuse(SwingTextMetrics.java:123)
at org.eclipse.birt.chart.device.TextAdapter.reuse(TextAdapter.java:36)
at org.eclipse.birt.chart.device.swing.SwingTextMetrics.<init>(SwingTextMetrics.java:86)
at org.eclipse.birt.chart.device.swing.SwingDisplayServer.getTextMetrics(SwingDisplayServer.java:194)
at org.eclipse.birt.chart.device.DisplayAdapter.getTextMetrics(DisplayAdapter.java:138)
at org.eclipse.birt.chart.computation.BIRTChartComputation.getTextMetrics(BIRTChartComputation.java:36)
at org.eclipse.birt.chart.computation.LegendBuilder$LegendData.<init>(LegendBuilder.java:108)
at org.eclipse.birt.chart.computation.LegendBuilder.compute(LegendBuilder.java:493)
at org.eclipse.birt.chart.model.layout.impl.LegendImpl.getPreferredSize(LegendImpl.java:2059)
at org.eclipse.birt.chart.internal.layout.LayoutManager$ChartLayout.<init>(LayoutManager.java:126)
at org.eclipse.birt.chart.internal.layout.LayoutManager.doLayout_tmp(LayoutManager.java:1145)
:
:
:
在Google God中快速搜索发现了这个有趣的StackOverflow线程 。 这是此线程的摘要。 Java使用linux的fontconfig功能搜索等宽,SansSerif和serif字体。 Linux fontconfig旨在在系统中定位字体,并根据应用程序指定的要求选择字体。 如果缺少上述任何一种字体,则将导致上述异常。
如果您还遇到这种类型的问题,有3种潜在的解决方案来解决此问题:
1.安装缺少的字体
2.升级JDK
3.编辑OS字体配置
让我们详细讨论解决方案。
1.安装缺少的字体
您可以通过发出以下命令来尝试安装缺少的字体:
yum install dejavu-serif-fonts
2.升级JDK
这是一个已知的JDK错误,在OpenJDK,Oracle和IBM JDK错误数据库中进行了跟踪:
- https://bugs.openjdk.java.net/browse/JDK-8188030
- https://bugs.java.com/bugdatabase/view_bug.do?bug_id=JDK-8188030
- http://www-01.ibm.com/support/docview.wss?uid=swg1IJ16655
自以下版本以来,此错误已得到修复:
开启JDK 8u192
甲骨文JDK 8u192
IBM JDK 8 SR5 FP37(8.0.5.37)
您可以升级到最新的JDK版本来解决此问题。
3.编辑OS字体配置
创建一个文件名/etc/fonts/local.conf。 在此文件中,将Utopia强制退回为Java使用的默认字体。
<?xml version= '1.0' ?> <!DOCTYPE fontconfig SYSTEM 'fonts.dtd' > <fontconfig>
<alias>
<family>serif</family>
<prefer><family>Utopia</family></prefer>
</alias>
<alias>
<family>sans-serif</family>
<prefer><family>Utopia</family></prefer>
</alias>
<alias>
<family>monospace</family>
<prefer><family>Utopia</family></prefer>
</alias>
<alias>
<family>dialog</family>
<prefer><family>Utopia</family></prefer>
</alias>
<alias>
<family>dialoginput</family>
<prefer><family>Utopia</family></prefer>
</alias> </fontconfig>
翻译自: https://www.javacodegeeks.com/2020/02/java-missing-font-crashing-app.html
在使用Eclipse MAT分析堆转储时遇到因缺失字体导致的ArrayIndexOutOfBoundsException问题。解决方案包括安装缺失的字体,升级JDK至8u192以上版本,或编辑Linux的字体配置文件。

2922

被折叠的 条评论
为什么被折叠?



