最近我们游戏经常收到玩家投诉卡进度条的问题。而且后台显示执行队列和CPU使用率异常高

根据调用的JDB分析出 使用xbean 时候会调用以下代码

在设置xmlobject 时候会有一个 GlobalLock.acquire();

当多线程并发设置xmlobject 时候造成互相等待这个GlobalLock 造成各个线程卡住,队列执行效率不高

所以我们目前解决方法就是直接用string 拼接成XML 暂时不用xbean 的功能

  1. public final XmlObject set(XmlObject src)
  2. {
  3. if (isImmutable()) {
  4. throw new IllegalStateException("Cannot set the value of an immutable XmlObject");
  5. }
  6. XmlObjectBase obj = underlying(src);
  7.  
  8. TypeStoreUser newObj = this;
  9.  
  10. if (obj == null)
  11. {
  12. setNil();
  13. return this;
  14. }
  15.  
  16. if (obj.isImmutable()) {
  17. set(obj.stringValue());
  18. }
  19. else {
  20. boolean noSyncThis = preCheck();
  21. boolean noSyncObj = obj.preCheck();
  22.  
  23. if (monitor() == obj.monitor())
  24. {
  25. if (noSyncThis) {
  26. newObj = setterHelper(obj);
  27. }
  28. else {
  29. synchronized (monitor()) {
  30. newObj = setterHelper(obj);
  31. }
  32.  
  33. }
  34.  
  35. }
  36. else if (noSyncThis)
  37. {
  38. if (noSyncObj)
  39. {
  40. newObj = setterHelper(obj);
  41. }
  42. else
  43. {
  44. synchronized (obj.monitor()) {
  45. newObj = setterHelper(obj);
  46. }
  47. }
  48. }
  49. else
  50. {
  51. if (noSyncObj)
  52. {
  53. synchronized (monitor()) {
  54. newObj = setterHelper(obj);
  55. }
  56.  
  57. }
  58.  
  59. boolean acquired = false;
  60. try
  61. {
  62. GlobalLock.acquire();
  63. acquired = true;
  64.  
  65. synchronized (monitor())
  66. {
  67. synchronized (obj.monitor())
  68. {
  69. GlobalLock.release();
  70. acquired = false;
  71.  
  72. newObj = setterHelper(obj);
  73. }
  74. }
  75. }
  76. catch (InterruptedException e)
  77. {
  78. throw new XmlRuntimeException(e);
  79. }
  80. finally
  81. {
  82. if (acquired) {
  83. GlobalLock.release();
  84. }
  85. }
  86. }
  87.  
  88. }
  89.  
  90. return (XmlObject)newObj;
  91. }

  

解决因为使用了官方xbean-2.4.0.jar 的库造成的性能问题的更多相关文章

  1. 一键解决Win10 LTSC 2021官方镜像存在的问题

    一键解决Win10 LTSC 2021官方镜像存在的问题 由于适用了win10 ltsc 2021之后,发现官方镜像存在一些致命的bug.但是本人又喜欢这个官方精简的系统,所以进行了一些修复.并将搜集 ...

  2. 完美解决AutoCAD2012,AutoCAD2013本身电脑里有NET4.0或以上版本却装不上的问题

    适用情况:电脑里本身有NET4.0或4.5版本,并且正确安装.或本身你就装有AutoCAD2013或AutoCAD2012要装AutoCAD2012或AutoCAD2013却装不上的情况 如图1所示. ...

  3. Nubia Z5S官方4.4 UI2.0音频Audio部分简单分析(也适用于其它8974/8064机型)以及降低破音出现几率的方法

    转载请注明出处和网址链接: http://blog.csdn.net/syhost/article/details/31419749 此篇本是在Z5S的官方4.4内測版出来时写的, 主要是看到其在au ...

  4. 解决Android微信支付官方demo运行失败

    Android微信支付官方demo运行失败,在此简单记录一下解决步骤 1.httpclient错误 官方给的demo是eclipse的,打开之后提示httpclient的错误,我知道在as下解决htt ...

  5. 同时安装Python2,Python3如何解决冲突问题【官方解法】

    使用py -2或py -3命令来区分调用Python启动器 去掉参数 -2/-3如何运行? 每次运行都要加入参数-2/-3还是比较麻烦,所以py.exe这个启动器允许你在代码中加入说明,表明这个文件应 ...

  6. NuGet Install-Package报错解决Package Manager Console error - PowerShell version 2.0 is not supported. Please upgrade PowerShell to 3.0 or greater and restart Visual Studio.

    问题: Package Manager Console error - PowerShell version 2.0 is not supported. Please upgrade PowerShe ...

  7. 解决Win8/8.1无法正确识别USB3.0的问题

    找一个USB3.0的移动硬盘到了手里竟然变成2.0的了!二了! 不能忍啊. 听说是快速启动的问题,但是开机速度快很诱人. 百度了其他解决方法,终于解决了. 下面摘录自: http://blog.csd ...

  8. 如何使用本地账户"完整"安装 SharePoint Server 2010+解决“New-SPConfigurationDatabase : 无法连接到 SharePoint_Config 的 SQL Server 的数据 库 master。此数据库可能不存在,或当前用户没有连接权限。”

    注:目前看到的解决本地账户完整安装SharePoint Server 2010的解决方案如下,但是,有但是的哦: 当我们选择了"完整"模式安装SharePointServer201 ...

  9. ReactNative官方中文文档0.21

    整理了一份ReactNative0.21中文文档,提供给需要的reactnative爱好者.ReactNative0.21中文文档.chm  百度盘下载:ReactNative0.21中文文档 来源: ...

随机推荐

  1. BeanUtils.copyProperties()方法和PropertyUtils.copyProperties()的区别

    首先两者来源于同一个包: import org.apache.commons.beanutils.BeanUtils; import org.apache.commons.beanutils.Prop ...

  2. Java8函数式编程

    在Java8的 java.util.function中包含以下几个接口 1.Function,先上源码 /* * Copyright (c) 2010, 2013, Oracle and/or its ...

  3. 山东省第七届ACM省赛------The Binding of Isaac

    The Binding of Isaac Time Limit: 2000MS Memory limit: 65536K 题目描述 Ok, now I will introduce this game ...

  4. 模板——Tarjan

    #include <cstdio> #include <cstring> #include <iostream> #include <vector> u ...

  5. PHP基础结业感想与总结!

    之前来传智是我认真调查和思考后得出的结论,我做程序员的第一目标是赚钱和学习技术,有一句话"艺多不压身".相信班上所有人的目标都是,这一点都不会庸俗,但是各个人的目的就未必一样了.我 ...

  6. 遗传算法在JobShop中的应用研究(part 5:解码)

    解码操作是整个遗传算法最重要的一步,在这步里面我们利用配置文件中的信息将染色体解码成一个有向无环图. 在介绍解码操作之前我们先来看一下配置文件,在part1绪论中我们已经介绍了一个车间调度问题的基本信 ...

  7. div盒子中子元素(子元素可能是盒子, 图片) 中居中的三种方法

  8. docker centos7 rabbitmq3.6.5

    docker run --name=rabbitmqtmp -ti centos7/jdk7 /bin/bash yum -y install make gcc gcc-c++ kernel-deve ...

  9. 把数据输出到Word (非插件形式)

    项目开发过程中,我们要把数据以各种各样的形式展现给客户.把数据以文档的形式展现给客户相信是一种比较头疼的问题,如果没有好的方法会 使得我的开发繁琐,而且满足不了客户的需求.接下来我会通过两种开发方式介 ...

  10. iOS - PackIpa App 打包

    前言 打包 ipa 的前提 证书的申请和设置和 "App 上架" 文章的一样 从第一步到第四步都是一样的.还有第六步的 1-3 都是一样的,从第四步开始变化. 1.Archive ...