1

完整代码:

using System;
using System.Linq;
using System.Activities;
using System.Activities.Statements;

namespace ManyAssemblies {

  class Program {

    public sealed class SayHelloActivity : Activity {
      readonly WriteLine writeLine = new WriteLine() { Text = "Hello Workflow 4" };
      public SayHelloActivity() {
        Implementation = () => { return writeLine; };
      }
    }


    static void Main(string[] args) {
      var wfDefinition = new SayHelloActivity();

      for (int i = 0; i < 100; i++) {
        WorkflowInvoker.Invoke(wfDefinition);
      }

      var allLoadedAssemblies = AppDomain.CurrentDomain.GetAssemblies();
      int wfAssemblesCount = allLoadedAssemblies
        .Where(a => a.FullName == 
"Workflow, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null").Count();
      Console.WriteLine(string.Format("There are {0} workflow assemblies in app domain.", wfAssemblesCount));
      Console.ReadLine();
    }
  }
}

此代码的输出:

...
Hello Workflow 4
Hello Workflow 4
Hello Workflow 4
There are 100 workflow assemblies in app domain.

每次执行 wf 定义都会创建新的动态程序集,该程序集会加载到当前应用程序域中。为什么?定义总是相同的,所以这不是必需的,IMO。这是 WF4 的设计缺陷吗?这种行为可以控制吗?

我正在为工作流实例构建主机。而且这个主机必须运行很长时间,比如几个月。即使只有很少的工作流定义,我最终会得到包含数千个动态程序集的应用程序域吗?这会扼杀我的表现并耗尽我的记忆吗?

4

1 回答 1

1

事实证明,这是因为附加的调试器。

如果我直接在命令提示符下运行代码,在这种情况下,应用程序域中没有“Workflow,Version=0.0.0.0,Culture=neutral,PublicKeyToken=null”程序集。

有趣的是没有。

这是否意味着在每个 WorkflowInvoker.Invoke(wfDefinition); 是否存在在实例竞争时卸载的动态程序集的构建?

但这是一个可能不会影响 wf 应用程序性能的实现细节。

感谢您的帮助

于 2010-09-01T07:03:21.557 回答