JAVA同步synchronized的问题
我编写了一个客户端和服务器的程序,其中服务器要实现多线程,为了测试是否真的能“同步”,我在操作中加入了synchronized关键字,并加入了Thread.sleep(1000),看看到底能不能同步:
我同步部分代码基本结构如下:synchronized(this){
打印进入该部分代码的时间;
操作;(包含Thread.sleep(1000))
打印即将离开该部分代码的时间
}
然后我运行了两个客户端,一个让服务器的一个线程修改数据,然后让另一个客户端查询修改后的数据,但是总是查不到(我感觉并没有将这部分代码上锁),之所以打印该时间也是为了验证这个:服务器的时间打印很奇怪:
修改进入时间
2018-05-16 05:19:43
查询进入时间
2018-05-16 05:19:44
修改离开时间
2018-05-16 05:19:43
查询离开时间
2018-05-16 05:19:44
我的问题:既然修改操作在查询前面,虽然时间上修改在查询前面,但是正常的打印顺序不应该是:修改时间,修改时间,查询时间,查询时间吗?而且后来我让线程sleep(10000),这么长的时间(我明显感觉到操作非常的慢),输出的修改和查询仍然是这样的形式,并且结果仍然是错误的(修改后的信息仍然查不到);
另外非常有意思的一件事:我把Thread.sleep(1000)写的位置是删除、修改操作之间(也就是说,修改操作之前必须线程沉睡,而删除操作之后线程才会沉睡,我在先用一个客户端删除操作时,明显能感觉到操作非常快(按钮很快就恢复了,要是选择修改操作很慢按钮才恢复),这之后再查询,果不其然,查询不到已经删除的信息,虽然这个操作是对的我很欣慰,但是怎么删除操作不需要睡一会?就因为它的代码在Thread.sleep(1000)的前面?可是他们明明在一个同步代码块里;
这部分的代码如下:
synchronized(this) {
Date d = new Date();
String s = null;
if(info.get(0).indexOf("修改")!=-1) {
System.out.println("修改进入时间");
DateFormat sdf2 = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");
s = sdf2.format(d);
System.out.println(s);
}
if(info.get(0).indexOf("查询")!=-1) {
System.out.println("查询进入时间");
DateFormat sdf2 = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");
s = sdf2.format(d);
System.out.println(s);
}
info1=this.search(info);
if(info.get(0).indexOf("删除")!=-1) {
//操作
}
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
if(info.get(0).indexOf("修改")!=-1) {
//操作
}
if(info.get(0).indexOf("添加")!=-1) {
//操作
}
toFile();//写回文件
if(info.get(0).indexOf("查询")!=-1||info.get(0).indexOf("更新")!=-1||info.get(0).indexOf("无条件")!=-1) {
//操作
}
if(info.get(0).indexOf("修改")!=-1) {
System.out.println("修改离开时间");
DateFormat sdf3 = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");
s = sdf3.format(d);
System.out.println(s);
}
if(info.get(0).indexOf("查询")!=-1) {
System.out.println("查询离开时间");
DateFormat sdf3 = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");
s = sdf3.format(d);
System.out.println(s);
}
}