大家帮忙看看,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();
}
}
}
}
https://bbs.csdn.net/topics/390957202
首先,static 变量的值在首次加载这个类的时候,值都是默认值的。
其次,Tomcat 会给每个浏览器请求分配一个工作线程去解析的,setLocalIPAndPort 这个方法应该是在某个 web 请求中调用的,多个浏览器同时访问时就是多线程在调用该方法,完成对静态变量的赋值动作。
看不到你的 setLocalIPAndPort 是怎么调用的,所以不好分析。可以肯定是有多个值是由多线程并发访问产生的,至于怎么产生的,楼主可以加上同步,并在打印之前打印线程名称看看结果。