- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个 Excel 插件(用 C# 编写),其中包含一个静态变量,该变量是单例数据缓存的核心:
static DataCache _instance;
这是通过三个不同的代码路径访问的:
编辑(#3):
根据首次调用这些代码路径的顺序,我发现我的代码在两个单独的 AppDomain 中运行。
来自功能区栏事件处理程序的所有访问都发生在名为“MyPlugIn.vsto”的 AppDomain 中。如果这是对我的 COM 对象的第一次访问,则所有后续调用(包括 RTD 调用)都发生在同一个 AppDomain 中。
但是,如果第一次访问是通过 RTD 接口(interface)进行的,则该调用和所有后续 RTD 调用都发生在名为“DefaultDomain”的 AppDomain 中。 (当加载带有嵌入式 RTD 公式的已保存文档时,会发生这种情况。)通过工具栏初始化和操作 DataCache 的后续调用仍然发生在“MyPlugIn.vsto”AppDomain 中。这意味着 RTD 公式始终运行,就像 DataCache 未初始化一样(因为一个 AppDomain 中设置的静态变量在另一个 AppDomain 中保持未初始化)。
VSTO 初始化时,Excel 或 VSTO 似乎正在创建 AppDomain。在此初始化之前通过 COM 互操作创建的对象位于默认 AppDomain 中,而之后创建的对象则位于 VSTO AppDomain 中。
无论我的 RTD 服务器对象是在哪个 AppDomain 中创建的,如何确保使用相同的 DataCache 实例?
最佳答案
您的静态变量肯定不会在 AppDomain 之间共享,因此考虑到不同的 AppDomain,您所看到的内容符合预期。
我认为它的工作原理是这样的:
VSTO 加载项在其自己的 AppDomain 中运行。如果您的缓存对象(或 RTD 服务器)的 COM 类工厂是从该 AppDomain 中创建的,它将被加载到调用 AppDomain 中。随后访问该 COM 类会发现它已经加载到进程中,并使用现有的实例。
但是,如果第一次激活是由 Excel 本身触发的,例如通过 RTD 调用,.NET 实现的 COM 对象将被加载到进程的默认 AppDomain 中。除非您创建非托管填充程序,否则您无法控制加载过程的这一部分,因为加载发生时“您的代码”并未运行。
我的一些建议:
为从 .NET 加载项公开的 RTD 调用创建一些包装函数。这样,您可以确保在调用 Excel 的 Application.RTD 进行真正的 RTD 设置之前加载 RTD 类。
通过用户定义的函数从 RTD 服务器访问实际缓存 - 这样 Excel 就会调用具有真实缓存的 AppDomain,即使它不是 RTD 服务器所在的当前 AppDomain .
尝试通过 Application.AddIns 获取外接程序对象...有一种方法可以获取实际的外接程序 COM 对象,并使用其上的某些接口(interface)来访问缓存。 ..
为您的 RTD 服务器创建一个非托管填充程序(在网络上搜索“COM 填充程序向导”)。以某种方式弄清楚如何加载 VSTO AppDomain,然后将 RTD 服务器加载到该 AppDomain 中。
看看是否有办法将 VSTO 加载项加载到默认 AppDomain 中。我不知道,但也许有一个标志或开关告诉“Microsoft Office Systems 加载程序”(或现在该部分的名称)不要创建隔离的 AppDomain。
正确答案:使用Excel-Dna (免责声明:我是开发人员)。它支持托管加载项中的功能区、RTD 和 UDF,无需注册,所有内容都会放入您的加载项 AppDomain 中。它是免费的,但需要一些时间和精力来移植您的东西 - RTD 很简单,但如果您使用大量 VSTO 辅助对象来访问功能区和工作表(表格等),您将需要考虑有点。
我希望这能给你一些想法。
--戈弗特--
关于.net - Excel 从两个不同的 AppDomain 调用 .NET 自动化服务器?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3955184/
谁能解释一下 Server.MapPath(".")、Server.MapPath("~")、Server.MapPath(@"之间的区别\") 和 Server.MapPath("/")? 最佳答案
我不知道,为什么我们要使用 Server.UrlEncode() & Server.UrlDecode()?!在 QueryString 中我们看到 URL 中的任何内容,那么为什么我们要对它们进行编
我已经通过 WHM 在我的一个域上安装了 ssl 证书。网站正在使用 https://xyz.com . 但是它不适用于 https://www.xyz.com .我已经检查了证书,它也适用于 www
我已经使用 WMI 检测操作系统上是否存在防病毒软件,itz 正常工作并通过使用命名空间向我显示防病毒信息,例如 win xp 和 window7 上的名称和实例 ID:\root\SecurityC
我们有 hive 0.10 版本,我们想知道是否应该使用 Hive Server 1 或 Hive Server2。另一个问题是连接到在端口 10000 上运行的 Hive 服务器,使用 3rd 方工
我想在 C++ 中使用 Windows Server API 设置一个 HTTPS 服务器,我使用了示例代码,它在 HTTP 上工作正常,但我就是不能让它在 HTTPS 上工作。 (我不想要客户端 S
我写了一个非常基本的类来发送电子邮件。我用 smtp 服务器对其进行了测试,它工作正常,但是当我尝试使用我公司的交换服务器时,它给出了这个异常: SMTP 服务器需要安全连接或客户端未通过身份验证。服
我的应用程序包含一个“网关”DataSnap REST 服务器,它是所有客户端的第一个访问点。根据客户端在请求中传递的用户名(基本身份验证),请求需要重定向到另一个 DataSnap 服务器。我的问题
我有一个 Tomcat 服务器和一个 Glassfish4 服务器。我的 Servlet 在 Tomcat 服务器上启动得很好,但在 Glassfish4 服务器上给我一个“HTTP Status 4
我在 vmware 上创建了一个 ubuntu 服务器。我用它作为文件服务器。如果我通过托管虚拟机的计算机进行连接,则可以访问它。我无法从同一网络上的其他计算机执行此操作。提前致谢! 最佳答案 首先确
如何重启 Rails 服务器?我从 开始 rails server -d 所以服务器是分离的 我知道的唯一方法就是去做ps 辅助 | grep rails 并 kill -9关于过程#但是像这样杀死进
我实际上正在尝试找到编写一个简单的 XMPP 服务器的最佳方法,或者找到一个占用空间非常小的服务器。我只关心XMPP的核心功能(状态、消息传递、群组消息传递)。目前还在学习 XMPP 协议(proto
我实际上正在尝试找到编写简单 XMPP 服务器的最佳方法,或者找到一个占用空间非常小的方法。我只关心 XMPP 的核心功能(统计、消息、组消息)。目前也在学习 XMPP 协议(protocol),所以
我们正在尝试从 Java JAX-RS 适配器访问 SOAP 1.1 Web 服务。 我们正在使用从 WSDL 生成的 SOAP 客户端。 但是当解码 SOAP 故障时,我们得到以下异常: ... C
目前,我和许多其他人正在多个平台(Windows、OS X 和可能的 Linux)上使用 Python HTTP 服务器。我们正在使用 Python HTTP 服务器来测试 JavaScript 游戏
我有一个连续运行的服务器程序(C#/.NET 2.0 on Linux with mono),我想从 PHP 脚本连接到它以在网站上显示状态信息。 目的是创建一个(某种)实时浏览器游戏(无 Flash
所以我有一个单页客户端应用程序。 正常流程: 应用程序 -> OAuth2 服务器 -> 应用程序 我们有自己的 OAuth2 服务器,因此人们可以登录应用程序并获取与用户实体关联的 access_t
我们刚刚将测试 Web 服务器从 Server 2008 升级到 Server 2012 R2。我们有一个部署我们网站的批处理脚本。当它将站点推送到服务器时,它现在失败了。奇怪的是,我可以使用相同的发
建议一些加载SpagoBI服务器的方法,我尝试了所有方法来解析spagobi服务器。在 Catalina 中,错误是 - * SEVERE: Unable to process Jar entry [
当我们点击应用程序服务器(apache tomcat)时,它会创建一个线程来处理我们的请求并与 tomcat 连接,建立连接,tomcat 创建另一个线程来处理请求并将其传递给连接,连接线程将其传递给
我是一名优秀的程序员,十分优秀!