- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试使用 glib/gmessages.h作为我的应用程序的日志系统。我的问题通过以下代码演示:
试验.c:
#include <glib/gmessages.h>
#include <stdio.h>
void my_handler(const gchar* log_domain, GLogLevelFlags log_level,
const gchar* message, gpointer user_data)
{
printf("My handler: %s", message);
}
int main()
{
g_log_set_handler (LOG_DOMAIN, G_LOG_LEVEL_WARNING | G_LOG_FLAG_FATAL |
G_LOG_FLAG_RECURSION, my_handler, NULL);
g_log(LOG_DOMAIN, G_LOG_LEVEL_WARNING, "Hello 1\n");
g_log(LOG_DOMAIN, G_LOG_LEVEL_WARNING | G_LOG_FLAG_RECURSION, "Hello 2\n");
return (0);
}
编译时
gcc trial.c -DLOG_DOMAIN=\"MY_APP\" `pkg-config --cflags --libs glib-2.0`
输出是:
~> ./a.out
My handler: Hello 1
(process:25133): MY_APP-WARNING (recursed) **: Hello 2
Aborted
为什么我的处理程序没有处理对 g_log
的第二次调用?感谢您的帮助。
最佳答案
由于您在第二次调用中使用了错误的参数,因此发送了中止信号。
您必须在 G_LOG_LEVEL_WARNING
和 G_LOG_FLAG_RECURSION
之间进行选择以使用 g_log 进行日志记录。
我猜你可以打2个电话
g_log(LOG_DOMAIN, G_LOG_FLAG_RECURSION, "Hello 2\n");
g_log(LOG_DOMAIN, G_LOG_LEVEL_WARNING, "Hello 2\n");
但我不确定这是一个好的做法。
G_LOG_LEVEL_WARNING | G_LOG_FLAG_RECURSION
参数错误。
关于c - glib/gmessages.h 中的日志处理程序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9393131/
我想在 GLib 中将整数值转换为字符串。是否有任何宏或函数?或者我可以在同一个双向链表中存储不同的数据类型吗? 最佳答案 gchar *my_string = g_strdup_printf("%i
所以基本上我正在编写以下步骤来创建基于 dbus 的应用程序。1. g_bus_watch_name(特定服务出现的回调)2. g_signal_connect 附加到服务提供的某些信号。 g_sig
所以基本上我正在编写以下步骤来创建基于 dbus 的应用程序。1. g_bus_watch_name(特定服务出现的回调)2. g_signal_connect 附加到服务提供的某些信号。 g_sig
我尝试使用JUCE框架构建cpp程序,但出现错误 make: *** No rule to make target '/usr/include/glib-2.0/glib/gurifuncs.h',
我有一些使用 dbus-glib 通过 dbus 编写服务器导出和接口(interface)。 我正在尝试编写一个将字节数组作为输入的方法,但是我很难确定在我的方法参数中使用什么类型。 例如,如果我有
我一直在研究 python-mpdor 的源代码它提到它是 gobject-based, for easy event handling (in the high-level client class
假设我有一个 GLib.Array并想将其转换为 Item[] ,我将如何在 Vala 中做到这一点? 最佳答案 首先,除非您需要与现有代码进行互操作,否则不要使用 GLib.Array。使用 GLi
我正在尝试使用 GLib 的 spawn_command_line_sync 将 echo 的输出通过管道传输到命令中方法。我遇到的问题是 echo 将整个命令解释为参数。 为了更好地解释,我在我的代
我似乎无法使用 glib.h 编译这个基本程序... #include glib.h #include stdio.h int main () { return ((glib_major_ver
我刚开始学习 vala。我尝试了来自 vala tutorial 的以下程序. class Demo.Hello : Glib.Object { public static int main( s
在调查一些性能问题时,我最终进入了 gthread-posix.c。 在那里我找到了如下代码: static void __attribute__((noinline)) g_mutex_lock_s
这个问题在这里已经有了答案: Undefined reference to 'pthread_create' — linker command option order (libraries bef
我正在学习使用 GLib 编写简单、高效的套接字服务器的基础知识。我正在试验 GSocketService。到目前为止,我似乎只能接受连接,但它们会立即关闭。从文档中我无法弄清楚我缺少的步骤。我希望有
我在 gobject 上阅读了一个维基百科页面,上面写着, Depending only on GLib and libc, GObject is a cornerstone of GNOME and
我尝试了sudo apt-get install libglib2.0-dev并得到了 libglib2.0-dev is already the newest version. 我仍然收到错误 co
所以我正在尝试使用 GtkSourceViewmm 在 C++ 中使用 GtkSourceView ,其文档和支持水平给我的印象是很长一段时间没有仔细研究它。但我始终是一个乐观主义者 :) 我正在尝试
我是编程新手。我正在创建一个 Qt GUI 应用程序。这是一个小的拼字游戏。问题是每当我在构建它后从命令提示符启动这个程序时,我都会在命令提示符下得到以下输出: JumbleGame 1.0 Laun
我正在尝试创建一个相当简单的使用自动工具的 BitBake 配方,您可以在这里看到: SUMMARY = "an example autotools recipe" LICENSE = "MIT" L
我正在尝试创建一个相当简单的使用自动工具的 BitBake 配方,您可以在这里看到: SUMMARY = "an example autotools recipe" LICENSE = "MIT" L
我正在查看一段代码,它直到最近才有效。基本上,我有一个 C++ 类,我在其中使用 G_LOCK_DEFINE 宏保护一个变量。 class CSomeClass { private: gulo
我是一名优秀的程序员,十分优秀!