当前位置: 代码迷 >> 综合 >> C#托管调试助手 “DisconnectedContext“:“针对此 RuntimeCallableWrapper 向 COM 上下文 0xcd9968 的转换失败,错误如下: 系统调用失败。
  详细解决方案

C#托管调试助手 “DisconnectedContext“:“针对此 RuntimeCallableWrapper 向 COM 上下文 0xcd9968 的转换失败,错误如下: 系统调用失败。

热度:56   发布时间:2024-02-27 15:38:01.0

错误提示:

托管调试助手 "DisconnectedContext"
  Message=托管调试助手 "DisconnectedContext":“针对此 RuntimeCallableWrapper 向 COM 上下文 0xcd9968 的转换失败,错误如下: 系统调用失败。 (异常来自 HRESULT:0x80010100 (RPC_E_SYS_CALL_FAILED))。原因通常是创建此 RuntimeCallableWrapper 的 COM 上下文 0xcd9968 已断开连接,或者该上下文正忙于执行其他操作,无法处理该上下文转换。将不会有代理服务于该 COM 组件上的请求,调用将直接转向该 COM 组件。这可能会导致损坏或数据丢失。要避免此问题,请确保在应用程序全部完成 RuntimeCallableWrapper (表示其内部的 COM 组件)之前,所有 COM 上下文/单元/线程都保持活动状态并可用于上下文转换。”

    此问题的出现时由于使用了Excel的COM,在多线程读取Excel的时候出现的,并且少量数据的时候不会出现,数据量大(测试时5000行左右)的时候才会出现问题代码是:

List<String[]> TaskDataList = new List<string[]>();
string[] sColumnText = new string[iColumnCount];
for (int k = 0; k < iColumnCount; k++)
{//问题代码sColumnText[k] = ((Microsoft.Office.Interop.Excel.Range)workSheet.Cells[j, k + 1]).Text.ToString();
}
TaskDataList.Add(sColumnText);

解决办法:声明的时候将Excel相关的实例修改为 dynamic

dynamic workBook = excelApp.Workbooks.Open(PathFileName, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing);

dynamic workSheet = (Worksheet)workBook.Worksheets.Item[1];