我在用VS 2017。在我的v6项目中,我得到了"OutOfMemory in mscorlib.dll“异常。我在这个项目中使用Roslyn,下面是我查找字段声明和参考的方法。
public static async Task FindFieldDeclarationAndReferencesAsync(string solutionPath, List<Violation> violations)
{
var msWorkspace = MSBuildWorkspace.Create();
var solution = await msWorkspace.OpenSolutionAsync(solutionPath);***//The solution I am passing to this workspace is 1 GB***
var documents = solution.Projects.SelectMany(x => x.Documents).ToList();
foreach (var violation in violations)//violations.Count is approximately 10
{
var classFile = documents.Where(x => x.FilePath == violation.FilePath).FirstOrDefault();
var model = await classFile.GetSemanticModelAsync();
var root = await classFile.GetSyntaxRootAsync();
var classDeclarationNode = root.DescendantNodes().OfType<ClassDeclarationSyntax>().Where(x => x.Identifier.Text == violation.ClassName).FirstOrDefault();
var fieldDeclarationNodeList = classDeclarationNode.DescendantNodes().OfType<FieldDeclarationSyntax>().Where(m => m.Modifiers.ToString().Contains("public const")).SelectMany(x => x.Declaration.Variables.Where(y => y.Identifier.Text == violation.FieldName)).FirstOrDefault();
ISymbol fieldSymbol = model.GetDeclaredSymbol(fieldDeclarationNodeList);
var fieldReferences = await SymbolFinder.FindReferencesAsync(fieldSymbol, solution);
violation.FieldDeclaration = fieldDeclarationNodeList;
violation.Replacement = Helpers.GetIdentifierReplacement(violation.FieldName);
violation.References = fieldReferences.SelectMany(item => item.Locations).ToList();
}
}当解决方案大小为1GB时,当创建工作区时将其传递给Roslyn,我是否得到了此异常?
异常详细信息:
System.OutOfMemoryException
HResult=0x8007000E
Message=Exception of type 'System.OutOfMemoryException' was thrown.
Source=mscorlib
StackTrace:
at System.Threading.ExecutionContext.Capture(StackCrawlMark& stackMark, CaptureOptions options) in f:\dd\ndp\clr\src\BCL\system\threading\executioncontext.cs:line 1281
at System.Threading.ExecutionContext.FastCapture() in f:\dd\ndp\clr\src\BCL\system\threading\executioncontext.cs:line 1190
at System.Runtime.CompilerServices.AsyncMethodBuilderCore.GetCompletionAction(Task taskForTracing, MoveNextRunner& runnerToInitialize) in f:\dd\ndp\clr\src\BCL\system\runtime\compilerservices\AsyncMethodBuilder.cs:line 916
at System.Runtime.CompilerServices.AsyncTaskMethodBuilder`1.AwaitUnsafeOnCompleted[TAwaiter,TStateMachine](TAwaiter& awaiter, TStateMachine& stateMachine) in f:\dd\ndp\clr\src\BCL\system\runtime\compilerservices\AsyncMethodBuilder.cs:line 543
at System.Runtime.CompilerServices.AsyncMethodBuilderCore.<>c.<ThrowAsync>b__6_1(Object state) in f:\dd\ndp\clr\src\BCL\system\runtime\compilerservices\AsyncMethodBuilder.cs:line 1034
at System.Threading.QueueUserWorkItemCallback.WaitCallback_Context(Object state) in f:\dd\ndp\clr\src\BCL\system\threading\threadpool.cs:line 1273
at System.Threading.ExecutionContext.RunInternal(ExecutionContext executionContext, ContextCallback callback, Object state, Boolean preserveSyncCtx) in f:\dd\ndp\clr\src\BCL\system\threading\executioncontext.cs:line 954
at System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state, Boolean preserveSyncCtx) in f:\dd\ndp\clr\src\BCL\system\threading\executioncontext.cs:line 901
at System.Threading.QueueUserWorkItemCallback.System.Threading.IThreadPoolWorkItem.ExecuteWorkItem() in f:\dd\ndp\clr\src\BCL\system\threading\threadpool.cs:line 1250
at System.Threading.ThreadPoolWorkQueue.Dispatch() in f:\dd\ndp\clr\src\BCL\system\threading\threadpool.cs:line 819
at System.Threading._ThreadPoolWaitCallback.PerformWaitCallback() in f:\dd\ndp\clr\src\BCL\system\threading\threadpool.cs:line 1161我在TaskManager中为我的进程检查了句柄,下面是值。

我想摆脱这一例外。请提出解决办法。
发布于 2018-08-27 10:48:11
我找到了使用Visual“诊断工具”窗口占用更多内存的对象。在代码的开始和结束时获取内存屏幕截图,并将两者进行比较,并修复了问题。
当violation.FieldDeclaration和violation.References对象数量庞大时,violations占用了大量内存。因此,在每次迭代结束时在finally块中设置这些finally已经为我解决了这个问题。
https://stackoverflow.com/questions/51707295
复制相似问题