C++ sd总线信号不调用cb功能
我有一个问题。在C++应用程序中,我使用SD总线和信号不调用回调函数。p> 我连接到org.freedesktop.login1,接口是org.freedesktop.DBus.Properties,成员是PropertiesChanged,路径是/org/freedesktop/login1/seat/seat0 在我的连接方法中,我有以下内容:C++ sd总线信号不调用cb功能,c++,linux,ipc,systemd,dbus,C++,Linux,Ipc,Systemd,Dbus,我有一个问题。在C++应用程序中,我使用SD总线和信号不调用回调函数。p> 我连接到org.freedesktop.login1,接口是org.freedesktop.DBus.Properties,成员是PropertiesChanged,路径是/org/freedesktop/login1/seat/seat0 在我的连接方法中,我有以下内容: sd_bus_add_match(m_bus, NULL, "interface='org.freedesktop.DBus.Properties'
sd_bus_add_match(m_bus, NULL, "interface='org.freedesktop.DBus.Properties',member='PropertiesChanged',path='/org/freedesktop/login1/seat/seat0',type='signal'", on_properties_changed, NULL)
更改属性的方法是:
static int on_properties_changed(sd_bus_message *m, void *userdata, sd_bus_error *ret_error) {
printf("got some signal");
}
所以,当我运行这个程序时,我也在cmd中运行了以下命令:¸
gdbus monitor --system --dest org.freedesktop.login1 --object-path /org/freedesktop/login1/seat/seat0
然而,当我从userA切换到userB时,我在cmd窗口中看到了以下行:
/org/freedesktop/login1/seat/seat0: org.freedesktop.DBus.Properties.PropertiesChanged ('org.freedesktop.login1.Seat', {'ActiveSession': <('c7', objectpath '/org/freedesktop/login1/session/c7')>}, @as [])
然后我也得到了适当的回应
Type=signal Endian=l Flags=1 Version=1 Priority=0 Cookie=2281
Sender=:1.0 Path=/org/freedesktop/login1/seat/seat0 Interface=org.freedesktop.DBus.Properties Member=PropertiesChanged
UniqueName=:1.0
MESSAGE "sa{sv}as" {
STRING "org.freedesktop.login1.Seat";
ARRAY "{sv}" {
DICT_ENTRY "sv" {
STRING "ActiveSession";
VARIANT "(so)" {
STRUCT "so" {
STRING "c2";
OBJECT_PATH "/org/freedesktop/login1/session/c2";
};
};
};
};
ARRAY "s" {
};
};
<>但是C++中没有调用回调函数。知道为什么不叫它吗
我正在使用Ubuntu 16.04,我的systemd版本是229。我找到了解决这个问题的方法。问题是我并没有被任何事件循环所吸引 因此,我创建了新函数run(),在这个函数中我说:
while(m_running) {
sd_bus_message *m = NULL;
r = sd_bus_process(m_bus, &m);
if (r < 0) {
//error handling
}
r = sd_bus_wait(m_bus, (uint64_t)-1);
if (r < 0) {
//error handling
}
}
while(m_运行){
sd_总线_消息*m=NULL;
r=sd_总线_进程(m_总线,&m);
if(r<0){
//错误处理
}
r=sd_总线_等待(m_总线,(uint64_t)-1);
if(r<0){
//错误处理
}
}
现在我在连接到signal之后调用这个函数,sd_bus_add_match的回调函数通常被调用我知道很可能您发布的代码只是一个示例,但是,我确实想知道,在sd_bus_进程之后,您拥有返回消息的所有权。如果您已完成,则应释放邮件(unref)。如图所示,此代码存在内存泄漏。
while(m_running) {
sd_bus_message *m = NULL;
r = sd_bus_process(m_bus, &m);
if (r < 0) {
//error handling
}
r = sd_bus_wait(m_bus, (uint64_t)-1);
if (r < 0) {
//error handling
}
}