[你要求简单的消息传递]
你真的需要 DBus 吗?
如果您要求在 C 应用程序和 Python 之间进行简单的消息传递,为什么不使用 Rabbit/ZeroMQ 之类的消息传递库呢?这些已经解决了与传递/接收消息相关的所有问题。
而且,如果您想将依赖关系降至最低,您可以使用 UNIX 套接字甚至一些简单的 TCP/UDP 数据报。
编辑:由于我试图说服您研究 ZeroMQ 作为您的 IPC 平台以及它是多么简单,所以这里有一个示例 C“客户端”向服务器发送完整的数据报,服务器会回复。
ZeroMQ Client Example in C:
// Hello World client
#include <zmq.h>
#include <string.h>
#include <stdio.h>
#include <unistd.h>
int main ( void )
{
printf ( "Connecting to hello world server…\n" );
void *context = zmq_ctx_new ();
void *requester = zmq_socket ( context, ZMQ_REQ );
zmq_connect ( requester, "tcp://localhost:5555" );
int request_nbr;
for ( request_nbr = 0; request_nbr != 10; request_nbr++ ) {
char buffer [10];
printf ( "Sending Hello %d…\n", request_nbr );
zmq_send ( requester, "Hello", 5, 0 );
zmq_recv ( requester, buffer, 10, 0 );
printf ( "Received World %d\n", request_nbr );
}
zmq_close (requester);
zmq_ctx_destroy (context);
return 0;
}
服务器也一样简单:
ZeroMQ Server Example in C
// Hello World server
#include <zmq.h>
#include <stdio.h>
#include <unistd.h>
#include <string.h>
#include <assert.h>
int main ( void )
{
// Socket to talk to clients
void *context = zmq_ctx_new ();
void *responder = zmq_socket ( context, ZMQ_REP );
int rc = zmq_bind ( responder, "tcp://*:5555" );
assert ( rc == 0 );
while ( 1 ) {
char buffer [10];
zmq_recv ( responder, buffer, 10, 0 );
printf ( "Received Hello\n" );
sleep ( 1 ); // Do some 'work'
zmq_send ( responder, "World", 5, 0 );
}
return 0;
}