背景:
今天在项目中遇到的一个遗留问题造成的Production Log:
因为多线程访问PrintEngine,两个Agent同时打印PDF的时候,一个若选择中文繁体,另一个选择中文简体,则可能会出现一份PDF中部分文字是繁体,部分文字是简体的BUG。
产生BUG的根本原因:
ProposalStyle.java
中的所有(20+个)FontFactoryGN16
是静态(static)变量,每个线程会初始化一次,这就导致了当线程1初始化完成后,后面准备使用的时候,线程2可能重新初始化,导致问题。FontFactoryGN16.java
中的static int chineseMode
也是共享变量,存在线程安全的问题。
解决办法:
ProposalStyle.java
中的所有FontFactoryGN16使用实例变量,这样性能会下降。
因为ProposalStyle里面的FontFactoryGN16被很多地方使用,所有采用正则表达式替换的方式进行全局替换。static int FontFactoryGN16.chineseMode
转为
static ThreadLocal<Integer> threadSafeChineseMode
,
getting:threadSafeChineseMode.get()
setting:threadSafeChineseMode.set(int chineseMode)