GTK+图形化应用程序开发学习笔记(二)—Glib库

时间:2022-09-02 23:56:02
在学习GTK+之前我们需要先学习一下 glib的有关知识。因为我们将会在以后的学习中遇到这些知识。由于本笔记不是专门介绍glib的,所以下面的介绍不会太详细。

 

一、什么是glib

       glib库是linux平台下最常用的c语言函数库,它具有很好的可移植性和实用性。glibgtk+库和gnome的基础。glib的各种实用程序具有一致的接口。glib为许多标准的、常用的C语言结构提供了相应的替代物。它的编码风格是半面向对象,标识符加了一个前缀“g”,这也是一种通行的命名约定。使glib库的程序都应该包含glib的头文件glib.h。如果程序已经包含了gtk .h则不需要再包含glib.h

      

二、glib的类型定义

       glib的类型定义不是使用C的标准类型,它自己有一套类型系统。它们比常用的C语言的类型更丰富,也更安全可靠。引进这套系统是为了多种原因。

      以下是glib基本类型定义:

      整数类型:gint8guint8gint16guint16gint32guint32gint64guint64。其中gint88位的整数,guint88位的无符号整数,其他依此类推。这些整数类型能够保证大小。不是所有的平台都提供64位整型,如果一个平台有这些, glib会定义G_HAVE_GINT64

      整数类型gshortglonggintshortlongint完全等价。

      布尔类型gboolean:它可使代码更易读,因为普通C没有布尔类型。Gboolean可以取两个值:TRUEFALSE。实际上FALSE定义为0,而TRUE定义为非零值。

      字符型gcharchar完全一样,只是为了保持一致的命名。

      浮点类型gfloatgdoublefloatdouble完全等价。

      指针gpointer对应于标准Cvoid *,但是比void *更方便。

      指针gconst pointer对应于标准Cconst void *(注意,将const void *定义为const gpointer是行不通的)。

 

三、glib的宏

       glib除了定义一些在c程序中常见的宏外,还定义了一些用于类型转换的宏。如

       GINT_TO_POINTER(p) 

       GPOINTER_TO_INT(p)     

       GUINT_TO_POINTER(p)

       GPOINTER_TO_UINT(p)

      这些宏允许在一个指针中存储一个整数,但在一个整数中存储一个指针是不行的。如果

要实现的话,必须在一个长整型中存储指针。

      例如,我们想把一个int型整数转换为pointer型数,我们

 

四、内存管理

       glib用自己的g_变体包装了标准的malloc( )free( ),即g_malloc() g_free( )。它们有以下几个小优点:

g_malloc()总是返回gpointer,而不是char *,所以不必转换返回值。

•如果低层的malloc ( )失败,g_malloc ( )将退出程序,所以不必检查返回值是否是NULL

g_malloc()对于分配0字节返回NULL

g_free()忽略任何传递给它的NULL指针。

 

 

1

名称:

g_malloc

功能:

分配内存空间

头文件:

#include <glib.h>

函数原形:

gpointer g_malloc(gulong size);

参数:

gulong 空间的大小

返回值:

指向空间的指针

 

 

 

 

 

 

 

 

2

名称:

g_free

功能:

释放内存空间

头文件:

#include <glib.h>

函数原形:

void g_free(gpointer mem);

参数:

mem志向空间的指针

返回值:

 

 

 

 

 

 

 

 

 

五、出错处理函数

3.

名称::

g_strerror

功能:

出错处理函数

头文件:

#include <glib.h>

函数原形:

gchar *g_strerror(gint errnum);

参数:

errnum   给定的错误代码

返回值:

一条对应于给定错误代码的错误字符串信息

      

 

 

 g_strerror返回一条对应于给定错误代码的错误字符串信息,例如“ no such process”等。

 

 4.

名称::

g_error

功能:

显示消息

头文件:

#include <glib.h>

函数原形:

void g_error(gchar *format,…);

参数:

format   出错信息

返回值:

      

 

g_error 函数显示应用软件中的严重错误。它在错误信息前加上了"** ERROR **",并结束程序的运行。只当可能发生导致程序退出的错误才使用这一函数.

 

5.

名称::

g_warning

功能:

显示消息

头文件:

#include <glib.h>

函数原形:

void g_warning(gchar *format,…);

参数:

Format   出错信息

返回值:

      

 

 

 g_warning当发生可恢复的错误而且程序能够继续运行时,函数g_warning在错误信息前加上 " ** WARNING ** ",。GTK+用这一函数向程序设计人员显示已经成功处理了的错误。

六、与错误无关的显示消息函数

6

名称:

g_message

功能:

显示消息

头文件:

#include <glib.h>

函数原形:

void g_message(gchar *format,…);

参数:

Format  信息

返回值:

       g_message函数显示与错误无关的消息。在传递的字符串前打印 "message:"

 

7

名称:

g_print

功能:

显示消息

头文件:

#include <glib.h>

函数原形:

void g_print(gchar *format,…);

参数:

format  信息

返回值:

       g_print函数通常用于调试。你可以在开发过程中使用g_print函数,并在实际使用时撤消它的功能。

 

       下面我们用上一节的程序验证着这些函数。

#include <gtk/gtk.h>

                                                                                                                                            

int main(int argc, char* argv[])

{

GtkWidget *window;

    gtk_init(&argc,&argv);

    window = gtk_window_new(GTK_WINDOW_TOPLEVEL);

gtk_widget_show(window);

g_print(“hello world”);

g_warning(“hello world”);

g_message(“hello world”);

//g_error(“hello world”);

    gtk_main();

    return FALSE;

}

       程序的运行结果为:

#gcc –o base base.c `pkg-config –cflags –libs gtk+-2.0`

#./base

hello world

** (base:8850) :  WARNIG ** : hello world

** Message: hello world

 

七、Timeout函数

    Timeout函数会隔一定时间(毫秒)就自动地调用一次。下面的函数用于添加一个Timeout函数。定时函数类似于回调函数(我们将在下节介绍)。

 

8

名称:

g_timeout_add

功能:

添加一个Timeout函数

头文件:

#include <glib.h>

函数原形:

gint gtk_timeout_add(guint32 interval,GtkFunction function,gpointer data);

参数:

interval   调用定时函数的时间间隔

function   要调用的函数定时函数

data      传递给定时函数的参数

返回值:

返回一个整形“标志“

      

       可以用下面的函数停止调用定时函数:

 

9

名称:

g_timeout_remove

功能:

停止调用定时函数

头文件:

#include <glib.h>

函数原形:

void gtk_timeout_remove(gint tag);

参数:

tag     g_timeout_add函数返回的标志

返回值:

      

       还可以让回调函数返回FA L S E0来停止调用定时函数。也就是说,要想让函数继续调用,必须让它返回一个非0值或T R U E

       定期调用的回调函数声明应该是下面的形式:

       gint timeout_callback( gpointer data );

 

下面是程序例子:

#include <gtk/gtk.h>

gint n=1;

gint function(gpointer data);                                                                                                                                            

int main(int argc, char* argv[])

{

GtkWidget *window;

gpointer data;

gint sign;

 

    gtk_init(&argc,&argv);

    window = gtk_window_new(GTK_WINDOW_TOPLEVEL);

gtk_widget_show(window);

sign=g_timeout_add(500,function,data);

    gtk_main();

    return FALSE;

}

 

gint function(gpointer data)

{

g_print(“hello”);

if(++n>5)

    return 0;

}

 

程序每隔500毫秒输出一个hello.输出5个结束。