.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();

}

}

}

}

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

相关推荐
该用户已不存在4 小时前
6个值得收藏的.NET ORM 框架
前端·后端·.net
小码编匠9 小时前
WPF 中的高级交互通过右键拖动实现图像灵活缩放
后端·c#·.net
追逐时光者9 小时前
一个基于 .NET 开源、简易、轻量级的进销存管理系统
后端·.net
唐青枫16 小时前
C#.NET 定时任务与队列利器:Hangfire 完整教程
c#·.net
hez20101 天前
Runtime Async - 步入高性能异步时代
c#·.net·.net core·clr
追逐时光者1 天前
.NET Fiddle:一个方便易用的在线.NET代码编辑工具
后端·.net
mudtools1 天前
.NET驾驭Word之力:玩转文本与格式
c#·.net
唐青枫2 天前
C#.NET 数据库开发提速秘籍:SqlSugar 实战详解
c#·.net
追逐时光者2 天前
精选 4 款基于 .NET 开源、功能强大的 Windows 系统优化工具
后端·.net
mudtools2 天前
.NET驾驭Word之力:理解Word对象模型核心 (Application, Document, Range)
c#·.net