繁体   English   中英

Windows在C#(.NET 2.0)中的进程间通信

[英]Interprocess communication for Windows in C# (.NET 2.0)

我以前从未在Windows上进行过IPC。 目前,我正在开发一对程序,一个标准的GUI / CLI应用程序和一个Windows服务。 该应用必须告知服务该怎么做。 因此,假设仅在本地进行通信,这两个过程的最佳通信方法是什么?

最好的地方定义为更健壮,更不易出错,而不是性能最高或最容易编写的地方。

代码示例将非常受欢迎,但不是必需的:-)

请注意,我在询问使用什么,标准TCP套接字,命名管道或仅其他一些通信方式。

谢谢!

.Net中的IPC可以使用以下方法实现:

世界足球联合会

使用命名管道需要.Net 3.0及更高版本。

代码示例


远程处理

.Net 1.0发布的原始IPC框架。 我相信远程处理将不再得到积极发展,建议您改用WCF。

代码示例

通过远程处理进行进程间通信 -使用TCP通道

资源资源


使用csharptest-net RpcLibrary的Win32 RPC

我最近遇到一个项目,该项目包装了Win32 RPC库,并创建了一个.net类库,该库可用于本地和远程RPC。

项目主页http : //csharptest.net/projects/rpclibrary/

MSDN参考:

还有一个在库顶部运行的google协议缓冲区rpc客户端: https : //code.google.com/p/protobuf-csharp-rpc/


WM_COPYDATA

为了完整起见,还可以将WIN32方法与WM_COPYDATA消息一起使用。 在.Net 1.1中,我之前曾使用过此方法来创建一个单实例应用程序,该应用程序从Windows资源管理器中打开多个文件。

资源资源

插座

使用自定义协议(较难)

仅对于本地用户,我们已成功使用命名管道。 避免了TCP的开销,并且(至少对于.NET)效率很高,同时还具有不错的API。

与Windows服务通信的标准方法是使用服务控制代码。 Windows服务可以接收从0到255的代码。0-127保留给系统。 128到255可用于自定义命令。

如果您需要使用数据库,xml,文件,tcp,http等将复杂的对象发送到服务,则除了用于发送控制命令(如重载配置,过程项等)外,还应使用此控制代码。

还有其他功能可用,例如查询服务。 请参阅Windows服务文档和api。

http://arcanecode.com/2007/05/30/windows-services-in-c-sending-commands-to-your-windows-service-part-7/

由于您限于.Net 2.0,因此WCF可能不是一个选择。 您可以将具有共享内存的.Net远程处理用作同一计算机上应用程序域之间的基础通信机制。 使用这种方法,您可以轻松地将进程放在不同的计算机上,并用网络协议替换共享内存协议。

我想补充一下讨论。 如果这是外面的方法,请责骂我-但是信号量(或多个信号量)不能用于基本的交流吗?

最好的选择是使用WCF。 您将能够在Windows服务中创建服务主机,并公开GUI应用程序可以使用的定义明确的界面。 如果愿意,WCF将允许您通过命名管道进行通信,或者可以选择任何其他通信协议,例如TCP,HTTP等。使用WCF,您将获得强大的工具支持和大量可用信息。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM