我不想通过它的路径杀死一个进程。但是当我使用这段代码时,我得到了一个win32Exception。
只完成了ReadProcessMemory或WriteProcessMemory请求的一部分
我将目标版本更改为x64但我仍然遇到同样的错误。
Process[] Processes = Process.GetProcessesByName("iw4");
if (Processes.Length >= 1)
{
for (int i = 1; i < Processes.Length; i++)
{
Process Process = Processes[i];
string processPath = Process.MainModule.FileName;
if (processPath == s + "\\iw4.exe")
{
if (!File.Exists(s + "\\localization.txt"))
{
Log.Data("killed process!");
Process.Kill();
}
}
}
}
堆栈追踪:
at System.Diagnostics.NtProcexssManager.GetModuleInfos(Int32 processId, Boolean firstModuleOnly)
at System.Diagnostics.Process.get_MainModule()
at LocalizationFix.Fix.checkLocalizationFile()
at LocalizationFix.Init.Main(String[] args)
at System.AppDomain._nExecuteAssembly(RuntimeAssembly assembly, String[] args)
at Microsoft.VisualStudio.HostingProcess.HostProc.RunUsersAssembly()
at System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state, Boolean ignoreSyncCtx)
at System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state)
at System.Threading.ThreadHelper.ThreadStart()
答案 0 :(得分:1)
问题不在于发布的代码中。它最有可能出现在LocalizationFix.Fix.checkLocalizationFile()
。
发布的帖子存在一个无关的问题,即您正在跳过进程列表中的第一个条目。 C#使用零相对索引。
也许你想要这样的东西:
foreach (var Process in Process.GetProcessesByName("iw4");
{
...
}
此外,按照惯例,局部变量名称的Pascal值较低。所以使用:
foreach (var process in Process.GetProcessesByName("iw4");
{
...
}