独立于操作系统的Python和C之间的程序间通信

我几乎不知道我在这里做了什么,我之前从未做过这样的事情,但我和朋友正在编写竞争的国际象棋程序,他们需要能够相互沟通。

他将主要用C语言编写,我的大部分内容将使用Python,我可以看到一些选项:

  • 或者写入临时文件或连续的临时文件。 由于通信不会以任何方式笨重,这可能会起作用,但对我来说似乎是一个丑陋的工作,程序将不得不继续检查更改/新文件,它只是看起来很难看。
  • 找到一些操纵管道的方法,即mine.py | ./his。 这似乎有点死路一条。
  • 使用套接字。 但是我不知道我会做什么,所以有人可以给我一些阅读材料的指针吗? 我不确定是否存在独立于操作系统,与语言无关的方法。 是否必须有某种管理服务器程序来管理?
  • 使用某种HTML协议,这似乎有点矫枉过正。 我不介意程序必须在同一台机器上运行。

人们推荐什么,我在哪里可以开始阅读?

如果您想要并且需要真正独立于OS,语言无关的进程间通信,套接字可能是最佳选择。

这将允许两个程序跨机器进行通信(无需更改代码)。

对于阅读材料,这是一个Python套接字编程如何 。

两种可能性:

  • 使用IP套接字。 Python文档中有一些示例 。 (如果你只使用基本的读/写东西,真的不是那么难。)另一方面,C中的套接字通常不那么简单。

  • 创建第三个应用程序。 它使用子进程启动两个应用程序,并通过管道与两个应用程序通信。 国际象棋应用程序必须只能读/写stdin / stdout。

    这具有额外的好处,该应用程序可以检查移动是否合法。 这有助于您发现错误并保持游戏公平。

您可以使用Protobuf作为程序间协议,并从每个文件的文件读取/写入。

您可以每n秒读取一次中间文件。

一旦你有了这个工作,你可以转向使用套接字,每个程序将启动一个服务器并等待连接。

变化应该很小,因为协议已经是protobuf。 因此,您必须更改的唯一位置是从套接字或文件中读取的位置。

在任何一种情况下,您都需要一个交换协议。

编辑

Ooops我误读了,我认为这是C ++。

无论如何,这是对protobuf的C支持,但仍在进行中

http://code.google.com/p/protobuf-c/

我会说只写一个包含黑白移动的xml文件。 标记在一个单独的文件中,并且确保只有转动它的程序才会写入该文件以便轮到他们。

这是一个建议的xml格式的链接,用于存储您的移动,另一个小组提出了http://www.xml.com/pub/a/2004/08/25/tourist.html

带有客户端/服务器模型的套接字……

基本上,您和您的朋友正在创建客户端的不同实现。

本地客户端显示游戏的可视化表示并存储棋子的状态(位置,杀死/未杀死)以及关于棋子能够/不能做什么的规则(可以使用哪些棋子以及是否可以进行哪些动作董事会的国家正在检查中)。

远程服务器存储关于玩家的状态(轮到它,获得的积分,是否赢得游戏)以及已经发生的移动列表。

当你移动时,你的客户会根据游戏规则validation移动,然后向服务器发送一条消息,说明我已经做了这个动作。

另一个客户端看到已经转弯,从服务器拉出最后一步,计算移动发生的位置,根据游戏规则validation移动,并在本地重放动作。 完成所有操作后,它现在允许用户进行下一步(如果游戏结束,则不允许)。

客户端/服务器游戏通信中最重要的部分是,在服务器上以尽可能少的状态发送尽可能少的数据。 通过这种方式,您可以在本地或全球范围内播放,只需很少或没有延迟。 只要您的客户在与对手的客户相同的规则下运行,一切都应该有效。

如果你想确保没有人可以通过黑客攻击他们的客户端版本来欺骗你,你可以在服务器上完成位置和规则计算,只是让客户端只是简单的回放机制。

套接字是最好的通信媒介的原因是:

  • 跨进程通信的限制几乎与跨节点通信一样困难
  • 所有系统都广泛支持网络
  • 如果你选择的话,很少或根本没有使用它的障碍
  • 网络function强大,灵活且经过validation

这就是为什么像数据库这样的许多主要系统使用套接字作为网络以及本地通信媒介的部分原因。