gpt4 book ai didi

c# - Worksheet.Name 导致 OutOfMemoryException

转载 作者:太空狗 更新时间:2023-10-29 20:42:08 25 4
gpt4 key购买 nike

.Net4 C# VSTO4 Excel 加载项:

下面的函数被调用的频率很高,比如说每秒:

   /// <summary>
/// Gets a unique identifier string of for the worksheet in the format [WorkbookName]WorksheetName
/// </summary>
/// <param name="workbook">The workbook.</param>
/// <param name="worksheet">The worksheet.</param>
/// <returns>
/// A unique worksheet identifier string, or an empty string.
/// </returns>
public static string GetWorksheetUniqueIdentifier(Workbook workbook, dynamic worksheet)
{
if (workbook == null) return string.Empty;
if (worksheet == null) return string.Empty;//Note: Worksheet can also be a diagram!

return string.Format("[{0}]{1}", workbook.Name, worksheet.Name);
}

一段时间后,我收到以下异常:

System.OutOfMemoryException
at System.Collections.Generic.Dictionary`2.Resize()
at System.Collections.Generic.Dictionary`2.Insert(TKey key, TValue value, Boolean add)
at Microsoft.CSharp.RuntimeBinder.Semantics.SYMTBL.InsertChildNoGrow(Symbol child)
at Microsoft.CSharp.RuntimeBinder.Semantics.SymFactoryBase.newBasicSym(SYMKIND kind, Name name, ParentSymbol parent)
at Microsoft.CSharp.RuntimeBinder.Semantics.SymFactory.CreateLocalVar(Name name, ParentSymbol parent, CType type)
at Microsoft.CSharp.RuntimeBinder.RuntimeBinder.PopulateLocalScope(DynamicMetaObjectBinder payload, Scope pScope, ArgumentObject[] arguments, IEnumerable`1 parameterExpressions, Dictionary`2 dictionary)
at Microsoft.CSharp.RuntimeBinder.RuntimeBinder.BindCore(DynamicMetaObjectBinder payload, IEnumerable`1 parameters, DynamicMetaObject[] args, DynamicMetaObject& deferredBinding)
at Microsoft.CSharp.RuntimeBinder.RuntimeBinder.Bind(DynamicMetaObjectBinder payload, IEnumerable`1 parameters, DynamicMetaObject[] args, DynamicMetaObject& deferredBinding)
at Microsoft.CSharp.RuntimeBinder.BinderHelper.Bind(DynamicMetaObjectBinder action, RuntimeBinder binder, IEnumerable`1 args, IEnumerable`1 arginfos, DynamicMetaObject onBindingError)
at Microsoft.CSharp.RuntimeBinder.CSharpInvokeMemberBinder.FallbackInvokeMember(DynamicMetaObject target, DynamicMetaObject[] args, DynamicMetaObject errorSuggestion)
at System.Dynamic.DynamicMetaObject.BindInvokeMember(InvokeMemberBinder binder, DynamicMetaObject[] args)
at System.Dynamic.InvokeMemberBinder.Bind(DynamicMetaObject target, DynamicMetaObject[] args)
at System.Dynamic.DynamicMetaObjectBinder.Bind(Object[] args, ReadOnlyCollection`1 parameters, LabelTarget returnLabel)
at System.Runtime.CompilerServices.CallSiteBinder.BindCore[T](CallSite`1 site, Object[] args)
at System.Dynamic.UpdateDelegates.UpdateAndExecute3[T0,T1,T2,TRet](CallSite site, T0 arg0, T1 arg1, T2 arg2)
at CallSite.Target(Closure , CallSite , Object , Object )
at TestAddIn.ExcelAccessor.GetWorksheetUniqueIdentifier(Workbook workbook, Object worksheet)
at TestAddIn.ExcelAccessor.GetCurrentWorksheetUniqueIdentifier()
at TestAddIn.ExcelAccessor.timerExcelObserver_Tick(Object sender, EventArgs e)--------------------------------------------------------------------------------------------------------

调用代码为:

  private static Timer timerExcelObserver = new Timer();

...

timerExcelObserver.Tick += new EventHandler(this.timerExcelObserver_Tick);
timerExcelObserver.Interval = 1000;
timerExcelObserver.Start();

...

private void timerExcelObserver_Tick(object sender, EventArgs e)
{
...
var updatedWorksheetIdentifierString = GetCurrentWorksheetUniqueIdentifier();
...
}

public static string GetCurrentWorksheetUniqueIdentifier()
{
return GetWorksheetUniqueIdentifier(ExcelApplication.ActiveWorkbook, ExcelApplication.ActiveSheet);
}

我不知道为什么会出现异常!

在 GetWorksheetUniqueIdentifier 中“使用”可能会有所帮助吗?

using(worksheet)
{
return string.Format("[{0}]{1}", workbook.Name, worksheet.Name);
}

有人回答吗?

最佳答案

尝试显式释放 COM 对象:

public static string GetCurrentWorksheetUniqueIdentifier()
{
var workbook = ExcelApplication.ActiveWorkbook;
var worksheet = ExcelApplication.ActiveSheet;

try
{
return GetWorksheetUniqueIdentifier(workbook, worksheet);
}
finally
{
if (workbook != null &&
Marshal.IsComObject(workbook))
Marshal.ReleaseComObject(workbook);

if (worksheet != null &&
Marshal.IsComObject(worksheet))
Marshal.ReleaseComObject(worksheet);
}
}

已知这可以解决某些与 Office 相关的场景中的内存问题。

关于c# - Worksheet.Name 导致 OutOfMemoryException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10816670/

25 4 0