C Programer  - 讨论区

标题:GLib库Lists模块编程示例

2014年02月04日 星期二 09:50

GLib库提供了标准的单向链表和双向链表数据结构的实现,并提供包括插入、删除、查找、遍历等操作的API。其一大特点是链表的节点使用了Slice Memory Allocator,内存使用效率非常好。

编程示例如下:

#include <stdio.h>
#include <glib.h>
#include <string.h>

void g_func_print(gpointer data,gpointer user_data) {
    printf("%s\n",data);
}

int main(int argc,char **argv) {

    GSList *sl=NULL;
    sl=g_slist_append(sl,"laomeng188@163.com");
    sl=g_slist_append(sl,"laozhang@gmail.com");
    sl=g_slist_prepend(sl,"laoli@qq.com");
    printf("length of list: %d\n",g_slist_length(sl));

    g_slist_foreach(sl,g_func_print,NULL);

    for(GSList *s=sl;s!=NULL;s=g_slist_next(s)) {
        printf("for loop: %s\n",s->data);
    }
    printf("\n");

    sl=g_slist_insert(sl,"xiaowang@163.com",1); 
    g_slist_foreach(sl,g_func_print,NULL);
    printf("\n");

    sl=g_slist_insert(sl,"xiaoxia@163.com",1); 
    g_slist_foreach(sl,g_func_print,NULL);
    printf("\n");

    sl=g_slist_delete_link(sl,g_slist_nth(sl,1));
    g_slist_foreach(sl,g_func_print,NULL);
    printf("\n");

    sl=g_slist_delete_link(sl,g_slist_nth(sl,1));
    g_slist_foreach(sl,g_func_print,NULL);
    printf("\n");
   
    g_slist_free(sl);

    GList *l=NULL;
    l=g_list_append(l,"a");
    l=g_list_prepend(l,"b");
    l=g_list_insert(l,"c",1);
    printf("first element: %s\n",g_list_first(l)->data);
    printf("last element: %s\n",g_list_last(l)->data);
    printf("previous element: %s\n",
            g_list_previous(g_list_last(l))->data);
    g_list_free(l);
    
    return 0;
}

参考资料:

https://developer.gnome.org/glib/2.39/glib-Singly-Linked-Lists.html

https://developer.gnome.org/glib/2.39/glib-Doubly-Linked-Lists.html

 

如下红色区域有误,请重新填写。

    你的回复:

    请 登录 后回复。还没有在Zeuux哲思注册吗?现在 注册 !

    Zeuux © 2025

    京ICP备05028076号