Ist der folgende Code Thread-Safe bei gleichzeitigem Zugriff auf List?
Addiert der Volatile hier einen Wert?Boolean zum Synchronisieren verwenden
class concurrentList{
private AtomicBoolean locked = new AtomicBoolean(true);
volatile List<Integer> list=new LinkedList<Integer>();
long start = System.currentTimeMillis();
long end = start + 60*100;
public void push(int e){
while(!locked.get());
list.add(e);
while(!locked.compareAndSet(true,false));
}
public int pop(){
int elem;
while(locked.get());
elem=(Integer)list.remove(0);
while(!locked.compareAndSet(false,true));
return elem;
}
....
}
Nicht sicher, warum Sie unterschiedliche Sperrbedingungen in der Push- und Pop-Methode haben. Aber abgesehen davon, warum nicht eine ['java.util.concurrent.Lock'] (https://docs.oracle.com/javase/lock/docs/api/java/util/concurrent/locks/Lock.html ? ist-extern = true) Objekt? – n247s