- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章Java同步函数代码详解由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
|
/*
同步函数
当函数中的代码全部放在了同步代码块中,那么这个函数就是同步函数
*/
//同步函数的锁是this锁,this是一个引用,this指向的对象就是锁
//下面证明一下同步函数的锁就是this
//创建两个线程,一个在同步代码块中执行,另一个在同步函数中执行
//同步代码块用的锁是obj,同步函数用的所是this
//这就导致了两个线程存在两把锁,会出现上次所说的安全问题,即出现错误数据
//只有两个线程同时用一把锁,才能解决多线程的安全问题
class
Ticket
implements
Runnable{
private
int
num =
50
;
//当用静态同步函数时,需要将对象也改为静态的
private
Object obj =
new
Object();
//加一个flag标记,一个线程得到CPU,判断flag值
//如果是true,让他在同步代码块中执行,一旦进去就出不来了,因为任务代码为死循环
//否则让他在同步函数中执行
boolean
flag =
true
;
public
void
run(){
if
(flag){
while
(
true
){
//同步代码块,这里用的锁是obj,与同步函数用不一样的锁,会出现安全问题
//synchronized(obj){
//将锁改为this,与同步函数为同一把锁,就没有问题了
synchronized
(
this
){
//如果下面是静态同步函数,则应该把this改为Ticket.class,同一把锁
if
(num>
0
){
//强制线程放弃CPU,睡眠的线程不会放弃锁
try
{Thread.sleep(
20
);}
catch
(InterruptedException e){e.printStackTrace();}
System.out.println(Thread.currentThread().getName()+
"...sale..."
+num--);
//1
}
}
//释放锁
}
}
else
{
while
(
true
){
fun();
}
}
}
////静态函数进内存的时候不存在对象,但是存在其所属类的字节码文件对象,属于Class类型的对象,
//锁必须是对象,字节码文件,也是个对象,所以,静态同步函数的锁就是其所属类的字节码文件对象
//public static synchronized void fun(){//锁为Ticket.class
//这个函数的代码都是同步代码块中的,所以这个函数可以修饰为同步的,即同步函数
public
synchronized
void
fun(){
if
(num>
0
){
//强制线程放弃CPU,睡眠的线程不会放弃锁
try
{Thread.sleep(
20
);}
catch
(InterruptedException e){e.printStackTrace();}
System.out.println(Thread.currentThread().getName()+
"...sale..."
+num--);
//1
}
}
}
class
test{
public
static
void
main(String[] args){
Ticket t =
new
Ticket();
Thread t1 =
new
Thread(t);
Thread t2 =
new
Thread(t);
t1.start();
//t1先启动,但是他并不一定能抢到CPU,主线程依旧拿着CPU
//主线程拿着CPU往下走,将flag改为了false,导致两个
//线程同时用的一个任务代码,即一把锁,不会出现安全问题,所以,应该在此处
//让主线程进入睡眠状态,主线程放弃CPU,然后t1立刻拿到CPU,
//这样t1就可以,在flag是true的情况下,进入同步代码块中执行
//所以t1用的就是obj锁,然后主线程再拿上CPU,将flag改为false
//t2拿上CPU时,flag就为false,所以进入的是同步函数中执行,
//同步函数用的锁是this,两把锁,肯定会出现线程安全问题,所以,
//如果想解决安全问题,将同步代码块的锁,也改为this,即可解决
//让主线程放弃CPU
try
{
Thread.sleep(
20
);
}
catch
(InterruptedException e){
e.printStackTrace();
}
t.flag =
false
;
t2.start();
}
}
|
总结 。
同步函数的锁是this,静态同步函数的锁是他所属类的字节码文件对象.
以上就是本文关于Java同步函数代码详解的全部内容,希望对大家有所帮助,感谢大家对我网站的支持! 。
原文链接:http://blog.csdn.net/qq_39776901/article/details/78165302 。
最后此篇关于Java同步函数代码详解的文章就讲到这里了,如果你想了解更多关于Java同步函数代码详解的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我正在实现 IMAP 客户端,但 IMAP 邮箱同步出现问题。 首先,可以从 IMAP 服务器获取新邮件,但我不知道如何从邮箱中查找已删除的邮件。 我是否应该从服务器获取所有消息并将其与本地数据进行比
我研究线程同步。当我有这个例子时: class A { public synchronized void methodA(){ } public synchronized void met
嗨,我做了一个扩展线程的东西,它添加了一个包含 IP 的对象。然后我创建了该线程的两个实例并启动它们。他们使用相同的列表。 我现在想使用 Synchronized 来阻止并发更新问题。但它不起作用,我
我正在尝试使用 FTP 定期将小数据文件从程序上传到服务器。用户从使用 javascript XMLHttpRequest 函数读取数据的网页访问数据。这一切似乎都有效,但我正在努力解决由 FTP 和
我不知道如何同步下一个代码: javascript: (function() { var s2 = document.createElement('script'); s2.src =
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 7 年前。 Improve this qu
一 点睛 1 Message 在基于 Message 的系统中,每一个 Event 也可以被称为 Message,Message 是对 Event 更高一个层级的抽象,每一个 Message 都有一个
一 点睛 1 Message 在基于 Message 的系统中,每一个 Event 也可以被称为 Message,Message 是对 Event 更高一个层级的抽象,每一个 Message 都有一个
目标:我所追求的是每次在数据库中添加某些内容时(在 $.ajax 到 Submit_to_db.php 之后),从数据库获取数据并刷新 main.php(通过 draw_polygon 更明显)。 所
我有一个重复动画,需要与其他一些 transient 动画同步。重复动画是一条在屏幕上移动 4 秒的扫描线。当它经过下面的图像时,这些图像需要“闪烁”。 闪烁的图像可以根据用户的意愿来来去去和移动。它
我有 b 个块,每个块有 t 个线程。 我可以用 __syncthreads() 同步特定块中的线程。例如 __global__ void aFunction() { for(i=0;i #
我正在使用azure表查询来检索分配给用户的所有错误实体。 此外,我更改了实体的属性以声明该实体处于处理模式。 处理完实体后,我将从表中删除该实体。 当我进行并行测试时,可能会发生查询期间,一个实体已
我想知道 SQLite 是如何实现它的。它基于文件锁定吗?当然,并不是每个访问它的用户都锁定了整个数据库;那效率极低。它是基于多个文件还是仅基于一个大文件? 如果有人能够简要概述一下 sqlite 中
我想post到php,当id EmpAgree1时,然后它的post变量EmpAgree=1;当id为EmpAgree2时,则后置变量EmpAgree=2等。但只是读取i的最后一个值,为什么?以及如何
CUBLAS 文档提到我们在读取标量结果之前需要同步: “此外,少数返回标量结果的函数,例如 amax()、amin、asum()、rotg()、rotmg()、dot() 和 nrm2(),通过引用
我知道下面的代码中缺少一些内容,我的问题是关于 RemoteImplementation 中的同步机制。我还了解到该网站和其他网站上有几个关于 RMI 和同步的问题;我在这里寻找明确的确认/矛盾。 我
我不太确定如何解决这个问题......所以我可能需要几次尝试才能正确回答这个问题。我有一个用于缓存方法结果的注释。我的代码目前是一个私有(private)分支,但我正在处理的部分从这里开始: http
我对 Java 非常失望,因为它不允许以下代码尽可能地并发移动。当没有同步时,两个线程会更频繁地切换,但是当尝试访问同步方法时,在第二个线程获得锁之前以及在第一个线程获得锁之前再次花费太长时间(比如
过去几周我一直在研究java多线程。我了解了synchronized,并理解synchronized避免了多个线程同时访问相同的属性。我编写此代码是为了在同一线程中运行两个线程。 val gate =
我有一个关于 Java 同步的简单问题。 请假设以下代码: public class Test { private String address; private int age;
我是一名优秀的程序员,十分优秀!