踏雪之_无痕 2019-10-26 09:26 采纳率: 0%
浏览 192

一个很奇怪的static问题

大家帮忙看看,static居然有多个值,这不合理啊。
1)这不可能是先后赋值的问题,因为如果值后,后面依然有空的。重复出现。
2)好像有三个不同的static(这不正常)
3)本身只有一个list,6个任务,现在输出的是3个list,18个任务,而且同样的任务有三个不同的实例,见hashcode,
有三个hashcode说明很可能有三个实例,就算三个实例是因为多线程的问题产生的,但static也三个什么意思。
图片说明图片说明图片说明图片说明

事实上我加了synchronized,但是效果依然如此,三个是1我可以认为是并发,但后面三个并发设置的ConfigSet.SERVER_IP也变成三个我没法理解(ConfigSet.SERVER_IP是static的)

2019-10-26 13:55:41==========BaseAction(15493888)===========1-----N
====aaaaa====BaseAction Path(/data/tomcat/webapps/dlp_oa/WEB-INF/classes/)=========

2019-10-26 13:55:45==========BaseAction(15493888)===========1-----N
====aaaaa====BaseAction Path(/data/tomcat/webapps/dlp_oa/WEB-INF/classes/)=========

2019-10-26 13:55:49==========BaseAction(15493888)===========1-----N
====aaaaa====BaseAction Path(/data/tomcat/webapps/dlp_oa/WEB-INF/classes/)=========

private static Integer count1 = 0;

private void startTask()
{
synchronized(count1)
{
if(count1<1)
{
if(Ustring.getNotNull(ConfigSet.taskPath))
{
String shutdown = ConfigSet.getParam("taskShutdown");
if(Ustring.getNotNull(shutdown))
{
TaskManager.setShutDown(shutdown);
}
count1++;
System.out.println(Udate.getTexttNowDate()+"==========BaseAction("+Thread.currentThread().hashCode()+")==========="+count1+"-----"+shutdown);

System.out.println("====aaaaa====BaseAction Path("+this.getFilePath()+")=========");
TaskManager.run();
}
}
}
}
  • 写回答

2条回答

      报告相同问题?

      相关推荐 更多相似问题

      悬赏问题

      • ¥30 关于#网络安全#的问题:非对称加密验证
      • ¥20 关于线性代数里施密特正交化和QR分解的疑问
      • ¥15 matlab超类包含解析错误
      • ¥15 python拖拽文件问题
      • ¥15 执行import paddle代码出现错误如何解决?
      • ¥15 hisat2align exited with value 137
      • ¥15 寻找大学生合作开发软件(Delphi)
      • ¥30 AndroidBench&eMMC内存测试速度&Android
      • ¥15 W10 文件共享失败 怎么解决
      • ¥20 b站私信完整导出的方法