如何利用python dbus来发送一个信号

http://blog.csdn.net/sahusoft/article/details/5931905


简介

dbus用于进程间通信,可以降低不同程序间的耦合性,dbus的原理同分布式计算很象,其中一个介绍原理的网址为:官方的 文档

用python来操作dbus很方便,python-dbus的教程: 教程 

 

一些官方例子: 例子

简单过程

1.首先要从dbus.service.Object继承,这样才可以输出方法和信号,同时调用dbus.service.Object来初始化bus类 型(Session bus or System bus),以及 对象路径

 class Msg(dbus.service.Object):
    def __init__(self,bus,object_path):
        dbus.service.Object.__init__(self,bus,object_path)

 

2.输出信号,先修饰,信号要传递的参数有signature确定,然后再定义信号函数,信号函数体本身没多大意义,有意义 的只在于函数体的参数,在dbus中的信号名就是这个信号函数的名字

 @dbus.service.signal(dbus_interface=MSG_INTERFACE_URI,
                         signature='as')           #发送了一个可变数组,但数组的类型要一致,这里都是string
    def msg_signal(self,msg_list):
        print "exported signal: ",msg_list   #这个没有意义

 

3..定义一个发送信号的函数,注意要返回True,否则如果调用timeout_add的时候,它执行了一次就会停下来, 不会重复执行,因为timeout_add碰到False的时候就会停止执行

发送信号,其实也就只是调用刚才修饰的信号函数而已

  def construct_msg(self):
        timeStamp = time.strftime(TIMEFORMAT)
        self.msg_signal(["1111",timeStamp,"This is the content","1 2 3"])
        return True

 

4.连接到bus,注意在连接前要先选好loop的类型,否则不让连接

 DBusGMainLoop(set_as_default=True)  #选好loop的类型
    bus = dbus.SessionBus()
    aMsg = Msg(bus,MSG_OBJ_PATH)    #将对象输出到bus中

    gobject.timeout_add(1000,aMsg.construct_msg)  #定时发送信号,知道其中的函数返回False为止
    loop = gobject.MainLoop()
    loop.run()


完整程序


 #!/usr/bin/python

import dbus
import dbus.service
from dbus.mainloop.glib import DBusGMainLoop
import time
import gobject

MSG_OBJ_PATH = "/com/example/msg"
MSG_INTERFACE_URI = "com.example.msg"

TIMEFORMAT = "%H:%M:%S"

class Msg(dbus.service.Object):
    def __init__(self,bus,object_path):
        dbus.service.Object.__init__(self,bus,object_path)

    @dbus.service.method(dbus_interface=MSG_INTERFACE_URI,
                         in_signature='', out_signature='s')
    def say_hello(self):
        return "hello, exported method"

    @dbus.service.signal(dbus_interface=MSG_INTERFACE_URI,
                         signature='as')
    def msg_signal(self,msg_list):
        print "exported signal: ",msg_list

    def construct_msg(self):
        timeStamp = time.strftime(TIMEFORMAT)
        self.msg_signal(["1111",timeStamp,"This is the content","1 2 3"])
        return True

if __name__ == "__main__":
    DBusGMainLoop(set_as_default=True)
    bus = dbus.SessionBus()
    aMsg = Msg(bus,MSG_OBJ_PATH)

    gobject.timeout_add(1000,aMsg.construct_msg)
    loop = gobject.MainLoop()
    loop.run()

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
DBus中,可以使用DBus API来监控某一个信号。具体步骤如下: 1. 创建DBus连接,可以使用dbus_bus_get()函数。 2. 使用dbus_connection_add_filter()函数注册一个消息过滤器,该过滤器将会接收到DBus连接中的所有消息。 3. 使用dbus_bus_add_match()函数添加一个匹配规则,该规则用于过滤出你要监控的信号。 4. 调用dbus_connection_read_write_dispatch()函数来等待DBus连接的消息。 5. 当你接收到符合匹配规则的信号时,你可以使用DBus API来处理该信号。 以下是一个简单的DBus信号监控的代码示例: ```C #include <dbus/dbus.h> #include <stdio.h> int main(int argc, char **argv) { DBusError err; DBusConnection *conn; dbus_error_init(&err); // 创建DBus连接 conn = dbus_bus_get(DBUS_BUS_SESSION, &err); if (dbus_error_is_set(&err)) { fprintf(stderr, "Connection Error (%s)\n", err.message); dbus_error_free(&err); } if (NULL == conn) { return 1; } // 注册消息过滤器 dbus_bus_add_match(conn, "type='signal',interface='org.freedesktop.DBus.Properties',member='PropertiesChanged'", &err); dbus_connection_flush(conn); while (true) { // 等待DBus连接的消息 dbus_connection_read_write_dispatch(conn, -1); // 处理接收到的DBus消息 DBusMessage *msg; while ((msg = dbus_connection_pop_message(conn))) { if (dbus_message_is_signal(msg, "org.freedesktop.DBus.Properties", "PropertiesChanged")) { printf("Received PropertiesChanged Signal\n"); // TODO: 处理接收到的信号 } dbus_message_unref(msg); } } return 0; } ``` 上面的代码中,我们注册了一个消息过滤器来接收所有的DBus消息,同时添加了一个匹配规则来过滤出我们要监控的信号。在主循环中,我们使用dbus_connection_read_write_dispatch()函数来等待DBus连接的消息,当我们接收到符合匹配规则的信号时,我们在while循环中使用DBus API来处理该信号

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值