gpt4 book ai didi

c# - "Fixed"/"Load Balanced"C# 线程池?

转载 作者:行者123 更新时间:2023-12-04 19:48:09 27 4
gpt4 key购买 nike

我有一个“昂贵”的 3rd 方组件。该组件不是线程安全的。所述组件托管在 WCF 服务内部(目前),因此......每次调用进入该服务时,我都必须更新该组件。

相反,我想做的是有一个包含 16 个线程的池,每个线程都启动自己的组件副本,并有一种机制来调用该方法并将其分发到 16 个线程之一并返回值。

所以一些简单的事情:

var response = threadPool.CallMethod(param1, param2);

可以阻止调用直到它得到响应,因为我需要响应才能继续。

有什么建议?也许我想多了,还有一个 ConcurrentQueue由 16 个线程提供服务可以完成这项工作,但现在确定方法返回值将如何返回给调用者?

最佳答案

WCF 已经使用线程池来管理它的资源,所以如果你在上面添加一个线程管理层,它只会变得很糟糕。如果可能,请避免这样做,因为您会在服务调用中发生争用。

在你的情况下我会做的只是使用一个 ThreadLocal或线程静态,将使用昂贵的对象初始化一次。此后它将可用于线程池线程。

那是假设您的对象在 MTA 线程上正常;我猜它来自您的帖子,因为听起来事情目前正在运行,但速度很慢。

有人担心会创建太多对象,并且随着池变得太大而使用太多内存。但是,在做任何其他事情之前,先看看实践中是否是这种情况。这是一个非常简单的策略,实现起来很容易试用。只有在您确实需要时才变得更复杂。

关于c# - "Fixed"/"Load Balanced"C# 线程池?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35305656/

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