Kir*_*ril 3 c# generics concurrency operator-overloading
我怎样才能使这个通用?
class AtomicReference
{
private Object _value;
public AtomicReference()
{
_value = new Object();
}
public AtomicReference(Object value)
{
OptimisticSet(value);
}
public Object CompareAndSet(Object newValue)
{
return Interlocked.Exchange(ref _value, newValue);
}
public void OptimisticSet(Object newValue)
{
do {
} while (_value == Interlocked.CompareExchange(ref _value, _value, newValue));
}
public Object Get()
{
return _value;
}
}
Run Code Online (Sandbox Code Playgroud)
我失败的尝试:
class AtomicReference<T>
{
private T _value;
public AtomicReference()
{
}
public AtomicReference(T value)
{
Set(value);
}
public T CompareAndSet(T newValue)
{
// _value is not an object that can be referenced
return Interlocked.Exchange(ref _value, newValue);
}
public void OptimisticSet(T newValue)
{
// I can't use the operator== with type T
do{}while(_value == CompareAndSet(newValue));
}
public T Get()
{
return _value;
}
}
Run Code Online (Sandbox Code Playgroud)
SLa*_*aks 11
您需要约束 T
为引用类型,如下所示:
class AtomicReference<T> where T : class {
private T _value;
public AtomicReference() { }
public AtomicReference(T value) {
OptimisticSet(value);
}
public T CompareAndSet(T newValue) {
return Interlocked.Exchange(ref _value, newValue);
}
public void OptimisticSet(T newValue) {
while (_value == CompareAndSet(newValue));
}
public T Get() {
return _value;
}
}
Run Code Online (Sandbox Code Playgroud)
编辑:我建议你也用属性替换方法:
public T Value {
get { return _value; }
set { while(_value == CompareAndSet(value)); }
}
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
538 次 |
最近记录: |