2

我正在使用一个库,该库是为基于输入数据执行模拟而创建的,具有单个入口点,例如Run(Data data).

然而不幸的是,该库在内部将值存储为静态成员(我不知道为什么,但我无法更改它),因此当多个线程在内部影响相同数据时尝试同时执行多个模拟时会出现问题.

我想同时运行多个模拟的原因是让用户能够指定一系列值,并让他们的所有输出聚合并以可比较的格式呈现。

最初我认为解决这个问题的最简单方法是编写一个简单的控制台应用程序,它可以作为一个单独的进程生成,以执行计算并转储结果。但是,需要将大量数据加载到内存中才能运行模拟并生成单独的进程,这意味着这些数据需要多次加载,并且比顺序运行模拟要慢得多,并且可能会占用几 GB的记忆。

所以基本上我正在寻找一种为每个线程创建本地存储的方法,如果我可以修改库,我会看到这样的代码:

[ThreadStatic]
public static int Foo { get; set; }

有没有办法在不修改它的情况下指定程序集/静态类声明以使用本地线程存储?或者也许是一种在运行时甚至有效地创建对同一程序集的多个引用的方法?

4

1 回答 1

1

您使用单独的控制台应用程序走在正确的轨道上,但由于启动成本如此之高,您需要一种更复杂的方法。

与其每次都生成一个新的控制台应用程序,不如创建一个可以与之通信的子进程池(通过 stdin/stdout 或其他一些进程间通信,如 wcf、远程处理或命名管道)。创建一个包装器/管理器类来跟踪这些进程,根据需要产生新的进程,并知道哪些进程正在使用中。当一个进程没有被使用时,它可以向它发送一个新的调用并等待结果。

您也可以通过将库多次加载到单独的 AppDomain 中来在内存中做同样的事情,但我个人认为单独的进程更容易、更安全。

于 2013-07-04T03:06:36.250 回答