我知道synchronize
在方法带来同步到该对象之前使用关键字。也就是说,运行对象的同一实例的2个线程将被同步。
但是,由于同步是在对象级别进行的,因此运行对象的不同实例的2个线程将不会同步。如果我们在Java类中有一个由该方法调用的静态变量,则希望它在该类的实例之间同步。这两个实例在2个不同的线程中运行。
我们可以通过以下方式实现同步吗?
public class Test
{
private static int count = 0;
private static final Object lock= new Object();
public synchronized void foo()
{
synchronized(lock)
{
count++;
}
}
}
确实是因为我们定义了一个lock
静态对象,并且正在使用该synchronized
锁的关键字,所以static
变量count
现在可以在class
实例之间进行同步Test?
有几种同步对静态变量的访问的方法。
使用同步静态方法。这将在类对象上同步。
public class Test {
private static int count = 0;
public static synchronized void incrementCount() {
count++;
}
}
在类对象上显式同步。
public class Test {
private static int count = 0;
public void incrementCount() {
synchronized (Test.class) {
count++;
}
}
}
在其他静态对象上同步。
public class Test {
private static int count = 0;
private static final Object countLock = new Object();
public void incrementCount() {
synchronized (countLock) {
count++;
}
}
}
在很多情况下,方法3是最好的,因为锁对象没有暴露在类之外。
问题内容: GlobalVariables类包含在我的框架中使用的不同变量,其中之一是WebDriver实例: GlobalInitializer包含用于初始化所有GlobalVariable的方法: //一些其他方法来初始化其他全局变量。} 我有许多GetElement类,它们使用驱动程序实例获取UI控件元素,例如: 我还有其他类在UI控件上执行一些操作(此类也使用全局变量),例如: 我在tes
假设有多个线程由运行相同函数实例的循环组成,但是每个迭代的开始都需要同步(所以首先完成的线程必须等待最后一个线程开始新的迭代)。在C++11中如何做到这一点? ... 这在大多数情况下都起作用,但有时会有一两个线程无法唤醒。 这些是全局变量: 这是在线程中循环运行的函数的末尾:
问题内容: 任何人都可以解释以下语句吗……“静态同步方法和非静态同步方法不会互相阻塞-它们可以同时运行” 问题答案: 锁定对象在静态方法和非静态方法上有所不同。静态方法将Class对象用作锁(锁obj:),而非静态方法将实例对象用作锁,此时方法的调用已绑定到该对象(锁obj:)。
我了解Class对象上的静态同步锁,以及Object实例上的非静态锁。 但是,在此问题的可接受答案中:同步块中的静态与非静态锁定对象 使用非静态锁定对象时: 线程1调用o1.foo() 线程2调用o1.foo(),将不得不等待线程1完成 线程3调用o2.foo(),它可以只继续,不介意线程1和2 为什么线程 3 可以继续而不考虑线程 1 和 2。线程 3 是否必须等待从线程 1 或 2 获取对象实
我使用TestNG是为了使用Appium并行运行自动移动测试。 我在一个类中有一个初始化AppiumDriver对象的方法。 我从我的TestNG类中调用这个方法,以便每个线程创建它自己的驱动程序实例。问题是,因为它是一个静态变量,当每个线程试图通过静态方法从另一个类访问驱动程序时: 始终存在冲突,因为每个线程只能访问AppiumDriver对象的单个实现。 我知道我可以绕过这一点,把所有这些代码
如何在将GUI保持为活动状态而不是Hibernate/等待状态的同时延迟进程或创建队列?