gpt4 book ai didi

c# - 为什么进程会丢失线程?

转载 作者:行者123 更新时间:2023-12-03 13:21:53 25 4
gpt4 key购买 nike

这是一些永久生成GUID的代码。我写它是为了学习线程。在其中,即使ConcurrentQueue是线程安全的,您也会在生成GUID并将其入队的位置上有一个锁。这是因为我的实际代码将需要使用NHibernate,因此我必须确保只有一个线程可以填充队列。

当我在任务管理器中监视此代码时,我注意到该过程将线程数从18(在我的计算机上)减少到14,但不少于14。这是因为我的代码不好吗?

如果有人认为合适,还可以重构吗?我喜欢较短的代码。

class Program
{
ConcurrentNewsBreaker Breaker;

static void Main(string[] args)
{
new Program().Execute();

Console.Read();
}

public void Execute()
{
Breaker = new ConcurrentNewsBreaker();
QueueSome();
}

public void QueueSome()
{
ThreadPool.QueueUserWorkItem(DoExecute);
}

public void DoExecute(Object State)
{
String Id = Breaker.Pop();
Console.WriteLine(String.Format("- {0} {1}", Thread.CurrentThread.ManagedThreadId, Breaker.Pop()));

if (Breaker.Any())
QueueSome();
else
Console.WriteLine(String.Format("- {0} XXXX ", Thread.CurrentThread.ManagedThreadId));
}
}


public class ConcurrentNewsBreaker
{
static readonly Object LockObject = new Object();

ConcurrentQueue<String> Store = new ConcurrentQueue<String>();

public String Pop()
{
String Result = null;
if (Any())
Store.TryDequeue(out Result);
return Result;
}

public Boolean Any()
{
if (!Store.Any())
{
Task FillTask = new Task(FillupTheQueue, Store);
FillTask.Start();
FillTask.Wait();
}

return Store.Any();
}

private void FillupTheQueue(Object StoreObject)
{
ConcurrentQueue<String> Store = StoreObject as ConcurrentQueue<String>;
lock(LockObject)
{
for(Int32 i = 0; i < 100; i++)
Store.Enqueue(Guid.NewGuid().ToString());
}
}
}

最佳答案

您正在使用.NET的ThreadPool,因此.NET/Windows根据等待处理的工作量来管理线程数。

关于c# - 为什么进程会丢失线程?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6621069/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com