我想用一個簡單的GTK +查看器作爲例子使用poppler和cairo,我發現它在gtkforums.com的工作。但是,我收到了分段錯誤(我使用anjuta)。GTK +程序中的分段錯誤
當我使用調試器我得到這個:
ID:1 文件:/usr/lib/i386-linux-gnu/libgdk-x11-2.0.so.0 行:0 功能:?? 地址:0x1d3f16(不要認爲反正事項)
終端消息在調試時:
Debug Terminal for the process: ------------------------------- &"warning: GDB: Failed to set controlling terminal: Operation not permitted\n"
GLib-GObject-WARNING **: cannot register existing type `GdkWindow'
GLib-GObject-CRITICAL **: g_object_new: assertion `G_TYPE_IS_OBJECT (object_type)' failed
這裏是我的代碼:
#include <config.h>
#include <glib/gi18n.h>
#include <stdio.h>
#include <stdlib.h>
#include <glib.h>
#include <gtk/gtk.h>
#include <gdk/gdk.h>
#include <cairo.h>
#include <poppler.h>
/* gcc `pkg-config --cflags --libs gtk+-2.0 poppler-glib` -o pdfviewer pdfviewer.c */
static PopplerDocument* doc;
static PopplerPage* page;
static void
on_destroy(GtkWidget* w, gpointer data) {
gtk_main_quit();
}
static gboolean
on_expose(GtkWidget* w, GdkEventExpose* e, gpointer data) {
cairo_t* cr;
cr = gdk_cairo_create(w->window);
poppler_page_render(page, cr);
cairo_destroy(cr);
return FALSE;
}
int main(int argc, char* argv[]) {
GtkWidget* win;
GError* err = NULL;
gtk_init(&argc, &argv);
doc = poppler_document_new_from_file("file:///home/user/test.pdf", NULL, &err);
if (!doc) {
printf("%s\n", err->message);
g_object_unref(err);
return 2;
}
page = poppler_document_get_page(doc, 0);
if(!page) {
printf("Could not open first page of document\n");
g_object_unref(doc);
return 3;
}
int pages = poppler_document_get_n_pages(doc);
printf("There are %d pages in this pdf.\n", pages);
win = gtk_window_new(GTK_WINDOW_TOPLEVEL);
g_signal_connect(G_OBJECT(win), "destroy", G_CALLBACK(on_destroy), NULL);
g_signal_connect(G_OBJECT(win), "expose-event", G_CALLBACK(on_expose), NULL);
gtk_widget_set_app_paintable(win, TRUE);
gtk_widget_show_all(win);
gtk_main();
g_object_unref(page);
g_object_unref(doc);
return 0;
}
你可以通過你的調試器並告訴我們seg故障發生的地方嗎?從這些代碼中,可能會發生一些地方。 – 2012-02-14 13:55:48
確保在啓用調試信息的情況下構建程序,以便調試器可以正確地告訴你它崩潰的位置。 – unwind 2012-02-14 13:56:30
我似乎找不到方法來複制所有的調試器消息,但這裏的錯誤:錯誤,msg =「不能訪問內存在地址0x0」 – Rrjrjtlokrthjji 2012-02-14 14:42:43