微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

c# – InvalidOperationException调用ResourceManager.GetString时

我的应用偶尔抛出异常:

Exception type: InvalidOperationException Exception message:
Collection was modified; enumeration operation may not execute.

这是堆栈跟踪

Exception type: InvalidOperationException 
    Exception message: Collection was modified; enumeration operation may not execute.
   at System.Reflection.RuntimeAssembly._nLoad(AssemblyName fileName,String codeBase,Evidence assemblySecurity,RuntimeAssembly locationHint,StackCrawlMark& stackMark,IntPtr pPrivHostBinder,Boolean throwOnFileNotFound,Boolean forIntrospection,Boolean suppressSecurityChecks)
   at System.Reflection.RuntimeAssembly.InternalGetSatelliteAssembly(String name,CultureInfo culture,Version version,StackCrawlMark& stackMark)
   at System.Resources.ManifestBasedResourcegroveler.GetSatelliteAssembly(CultureInfo lookForCulture,StackCrawlMark& stackMark)
   at System.Resources.ManifestBasedResourcegroveler.grovelForResourceSet(CultureInfo culture,Dictionary`2 localResourceSets,Boolean tryParents,Boolean createIfNotExists,StackCrawlMark& stackMark)
   at System.Resources.ResourceManager.InternalGetResourceSet(CultureInfo requestedCulture,StackCrawlMark& stackMark)
   at System.Resources.ResourceManager.InternalGetResourceSet(CultureInfo culture,Boolean tryParents)
   at System.Resources.ResourceManager.GetString(String name,CultureInfo culture)

这是我的代码

public IList<Function> MapWithLanguage(IList<Function> list)
{
    if (list == null)
    {
        return null;
    }
    var currentResource = Type.GetType("Fanex.Athena.Models.viewmodel.Menu,Fanex.Athena.Models");
    ResourceManager rm = new ResourceManager(currentResource);
    var newList = new List<Function>();
    foreach (var func in list)
    {
        newList.Add(new Function
        {
            Name = rm.GetString("Menu_" + func.FunctionId),});
    }
    return newList;
}

有人可以帮忙吗?太奇怪了!

解决方法

经过长时间的检查,我找到了根本原因.
这是我的代码导致上述问题:
AppDomain.CurrentDomain.GetAssemblies().

因为此方法尝试加载生成的程序集,如“web_adg_gfgt_dfd.dll”,并且可以在IIS回收时删除它们.为了修复它,我们只需要避免加载“生成的程序集”.

因此我们有两种方法可以解决

1.过滤“生成的组件”:

AppDomain.CurrentDomain.GetAssemblies().Where(i => i.IsDynamic == false).ToList()

2.使用这种方法

BuildManager.GetReferencedAssemblies().Cast<Assembly>().ToList()

原文地址:https://www.jb51.cc/csharp/99214.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐