.NET 终止或结束进程

如何使用 C# 终止进程。

使用简单的方法终止.NET中的现有进程Process.Kill()。有一个可选参数 true 或 false,用于结束与要结束的进程相关的所有子进程。

了解如何创建流程

结束当前进程:

System.Diagnostics.Process.GetCurrentProcess().Kill(true);

结束当前计算机上所有名为"notepad"的进程:

static void KillAllNotepadProcesses()

{

System.Diagnostics.Process[] procs = System.Diagnostics.Process.GetProcessesByName("notepad", "."); // use "." for this machine

foreach (var proc in procs)

proc.Kill(true);

}

要结束另一台计算机上名为"notepad"的所有进程:

static void KillAllNotepadProcesses()

{

System.Diagnostics.Process[] procs = System.Diagnostics.Process.GetProcessesByName("notepad", "Machine-Name-or-IP-Address"); // enter the IP address or machine name

foreach (var proc in procs)

proc.Kill(true);

}

结束当前进程的所有其他实例:

static void KillAllOtherInstances()

{

System.Diagnostics.Process thisProc = System.Diagnostics.Process.GetCurrentProcess();

System.Diagnostics.Process[] procs = System.Diagnostics.Process.GetProcessesByName(thisProc.ProcessName, "."); // use "." for this machine

foreach (var proc in procs)

if (proc.Id != thisProc.Id) // the process Id is unique across all processes while the process name can be common

proc.Kill(true);

}

完整的现实示例:

为了扩展上述代码片段,我们准备了以下代码。它使用强力算法来解决π,这对 CPU 来说非常耗电。因此,它会终止(杀死)自身的所有其他实例,以防止机器负担过重。编译此代码并尝试运行多个实例!

using System;

using System.Collections.Generic;

using System.Linq;

using System.Threading;

using System.Threading.Tasks;

namespace KillOtherInstancesAndSolvePI

{

class JobTask

{

public Task task { get; }

public int id { get; }

public double pi { get; set; }

public ulong iterations { get; set; }

public CancellationTokenSource CancelToken { get; }

public JobTask(int id)

{

this.id = id;

CancelToken = new CancellationTokenSource();

task = Task.Run(async () => // async not necessary in this example

{

var spaces = Environment.ProcessorCount.ToString().Length;

iterations = (ulong)new Random().Next() * 10;

Console.WriteLine("Started Job: {0, -" + spaces + "} Iterations: {1}", id, iterations);

pi = SolvePi(iterations, CancelToken);

Console.WriteLine("Job: {0, -" + spaces + "} ended with pi={1}", id, pi.ToString("0.00000000000000"));

}, CancelToken.Token);

}

static double SolvePi(ulong count, CancellationTokenSource cancel)

{

//π = 3.14159265358979323846264338327950288419...

//π = (4/1) - (4/3) + (4/5) - (4/7) + (4/9) - (4/11) + (4/13) - (4/15) + ...

//π = 4 * (1 - 1/3 + 1/5 - 1/7 + 1/9 - 1/11 + 1/13 - 1/15 + ...)

double x = 1.0;

for (ulong i = 2; !cancel.IsCancellationRequested & (i < count); i++)

{

if ((i & 1) == 0)

x -= 1.0 / ((i << 1) - 1);

else

x += 1.0 / ((i << 1) - 1);

}

return 4.0 * x;

}

}

class Program

{

static void KillAllOtherInstances()

{

System.Diagnostics.Process thisProc = System.Diagnostics.Process.GetCurrentProcess();

System.Diagnostics.Process[] procs = System.Diagnostics.Process.GetProcessesByName(thisProc.ProcessName, ".");

foreach (var proc in procs)

if (proc.Id != thisProc.Id)

proc.Kill(true);

}

static void Main(string[] args)

{

KillAllOtherInstances(); // end the other process before trying to solve PI

var jobTasks = new List<JobTask>();

Console.WriteLine("pi={0}", 3.1415926535897932384626433833.ToString("0.00000000000000"));

Console.WriteLine("Logical Processors: {0}", Environment.ProcessorCount);

Console.WriteLine("ENTER JOB NUMBER TO TERMINATE AT ANYTIME");

var spaces = Environment.ProcessorCount.ToString().Length;

int[] jobsIds = new int[Environment.ProcessorCount];

for (int i = 0; i < Environment.ProcessorCount; i++)

jobsIds[i] = i;

foreach(var jobId in jobsIds)

jobTasks.Add(new JobTask(jobId));

Thread.Sleep(250);

foreach (var j in jobTasks.OrderBy(j => j.iterations))

Console.WriteLine("Job: {0, -" + spaces + "} Iterations: {1}", j.id, j.iterations);

Task.Run(() => // create a task to terminate the app when all pi tasks are done

{

while (jobTasks.Where(j => j.task.IsCompleted == false).Count() > 0)

Thread.Sleep(250);

Environment.Exit(0);

});

while (jobTasks.Where(j => j.task.IsCompleted == false).Count() > 0) // look for a request to cancel a job from the user

{

var id = Console.ReadLine();

JobTask jt = jobTasks.Where(j => j.id.ToString() == id).FirstOrDefault();

if(jt != null)

jt.CancelToken.Cancel();

}

}

}

}

如果您喜欢此文章,请收藏、点赞、评论,谢谢,祝您快乐每一天。

相关推荐
guizhoumen6 小时前
liunx环境手动安装.net8的教程
.net
全栈小510 小时前
【C#】.net 6.0和8.0有什么区别,以及8.0增加了那些功能,这些功能有那些作用
开发语言·c#·.net
qq_2979080110 小时前
C#印刷线路板ERP进销存报价财务库存贸易生产企业管理系统软件
sqlserver·开源·c#·.net·开源软件
专注VB编程开发20年1 天前
WebView2 处理跨域访问限制,Frame脚本执行,难度比CEF大10倍
前端·javascript·.net
weixin_421994782 天前
基于 .NET 9.0 的高性能轻量级令牌桶限流服务
.net·.netcore·令牌桶
weixin_421994782 天前
MVC 模式初探
mvc·.net·.netcore
无风听海3 天前
.NET10之AppContext
.net
微八度3 天前
.Net Web API应用部署成windows服务
windows·.net·web api·winddows服务
无风听海3 天前
.NET10之Middleware 和 Filter
.net