加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – ConcurrentStack:如何检查是否包含对象?

发布时间:2020-12-16 01:27:42 所属栏目:百科 来源:网络整理
导读:如何检查它是否包含堆栈中的特定对象? private ConcurrentStackint cs = new ConcurrentStackint();cs.Push(1); 解决方法 方法 StackT.Contains 在 ConcurrentStackT -class中不可用.我想因为那不是线程安全的. 因此,如果您需要它,您必须使用锁,然后您可以
如何检查它是否包含堆栈中的特定对象?

private ConcurrentStack<int> cs = new ConcurrentStack<int>();
cs.Push(1);

解决方法

方法 Stack<T>.ContainsConcurrentStack<T>-class中不可用.我想因为那不是线程安全的.

因此,如果您需要它,您必须使用锁,然后您可以使用Enumerable.Contains:

private ConcurrentStack<int> cs = new ConcurrentStack<int>();
private Object csLockObject  = new Object();

bool contains = false;
lock (csLockObject)
{
    contains = cs.Contains(1);
}

但是,当您枚举此快照时,另一个线程可能会向堆栈添加项目或从堆栈中删除项目.如果您想要防止在添加/删除的位置还需要锁定.

I want to avoid duplicates

好吧,你可以使用这样的类,它使用ConcurrentDictionary来检查它是否是唯一的:

public class ConcurrentUniqueStack<T>
{
    private readonly ConcurrentDictionary<T,int> _itemUnique; // there is no ConcurrentHashSet so we need to use a Key-only dictionary
    private readonly ConcurrentStack<T> _stack;

    public ConcurrentUniqueStack() : this(EqualityComparer<T>.Default)
    {
    }
    public ConcurrentUniqueStack(IEqualityComparer<T> comparer)
    {
        _stack = new ConcurrentStack<T>();
        _itemUnique = new ConcurrentDictionary<T,int>(comparer);
    }

    public bool TryPush(T item)
    {
        bool unique = _itemUnique.TryAdd(item,1);
        if (unique)
        {
            _stack.Push(item);
        }

        return unique;
    }
    public bool TryPop(out T result)
    {
        bool couldBeRemoved = _stack.TryPop(out result);
        if (couldBeRemoved)
        {
            _itemUnique.TryRemove(result,out int whatever);
        }
        return couldBeRemoved;
    }

    public bool TryPeek(out T result) => _stack.TryPeek(out result);
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读