陈皓专栏 【空谷幽兰,心如皓月】

芝兰生于深谷,不以无人而不芳;君子修道立德,不为困穷而改节。

用户操作
[即时聊天] [发私信] [加为好友]
陈皓ID:haoel
485124次访问,排名97好友51人,关注者74
芝兰生于空谷,不以无人而不芳;君子修道立德,不为困穷而改节。
haoel的文章
原创 71 篇
翻译 0 篇
转载 0 篇
评论 1052 篇
陈皓的公告
Email & MSN
haoel@hotmail.com
最近评论
liuxi:LS 两个command都是命令的意思 例如 cc -o test.o -c -g test.c这样的命令.
targets : prerequisites ; command
command
这个的意思是命令你可以选择写在先决条件(prerequisites)的后面用分号隔开;也可以另起一行用tab开始些命令。
figoshen:楼上的,楼主的程序我跑了没有问题,你说的的多加(int*)是问题我觉得加不加都一样了
silvervi:大哥,文章有错误

在VS 2005里面加了断点专门跑了一下,对照局部变量里面虚函数表的实际地址,错误跟我之前想的一样,少了一次解引用

正确的应该如下

cout << "虚函数表地址:" << (int *)*(int *)(&b) << endl;

cout &……
miansha:走过留名

谢谢LZ,学习并谨记
new_my_program:我还是个学生,但就我们学生的角度来看,像清华大学出版社你们这些人是没资格出书的。一个老师如果教育学生犯罪那就是个垃圾老师,你们出书的本来更是影响几代人,比一般的老师的影响力更大的多,你们的垃圾程度是可想而知的。以前看了《清华梦的破灭》这个文章后,我对心目中的清华园产生了严重的鄙视,现在再看了陈皓大哥的帖子,我更是鄙视你们。进清华的学生是何等的厉害,何等的意气风发。但是出清华的学生呢,好的就留……
文章分类
收藏
    相册
    我的BLOG
    耗子小筑(非技术)(RSS)
    陈皓专栏(技 术)(RSS)
    存档
    订阅我的博客
    XML聚合  FeedSky
    订阅到鲜果
    订阅到Google
    订阅到抓虾
    订阅到BlogLines
    订阅到Yahoo
    订阅到GouGou
    订阅到飞鸽
    订阅到Rojo
    订阅到newsgator
    订阅到netvibes

    原创 用C写有面向对象特点的程序收藏

    新一篇: 哈希表心得 | 旧一篇: 哈希表心得

    比如在一个项目中,有大量的数据结构,他们都是双向链表,但又想共用一套对链表的操作算法,这怎么做到呢,C中又没有C++中的继承,不然我可以继承一父(类中只有两个指针,一个向前一个向后),而其算法可以写在你类中的虚函数中,供子类使用。如:

    class Links
    {
    public:
        Links* back;
        Links* forword;

        virtual Add(){ ... };
        virtual Del(){ ... };
        virtual Ins(){ ... };
        virtual Print() =0;
        ....

    };

    于是对于特定的数据结构我们可以:
    class mylinks : public Links
    {
    public:
        char* myname;
        char sex;
        int  age;
        ...
        virtual Print(){ .... }

    };
    对其操作时都可以使用你类的泛型算法。


    在C中,该如何做呢?我们用C中的指针和强制类型转可以做到。

    下面是我总结出来的一个小的程序,体现了用指针的弹性来实现这一继承的效果:
    (我在Liniux下的GCC调试通过)

    =======================================

    #include <stdio.h>

    /* 双向链表 (类似于父类)*/
    typedef struct hLinks{
       struct hLinks *bwLink;
       struct hLinks *fwLink;
    } hLinks;


    /*
     * 一个使用双向链表的结构
     *     (类似于子类)
     */

    typedef struct hEnt{
       hLinks links;
       int hData;
       char key[10];
    } hEnt;


    /*
     *  双向链插入泛型算法 (类似于父数中的成员函数)
     */

    Insert( hLinks* elem, hLinks *dest )
    {
       if ( !elem || !dest ) return;

       elem->bwLink = dest->bwLink;
       elem->fwLink = dest;
       dest->bwLink->fwLink = elem;
       dest->bwLink = elem;
    }


    /*
     *  打印 (类似于子类重载父类的成员函数)
     */

    PrintLink( hLinks *h )
    {
        hEnt *p ;

        for( p = ( hEnt* ) h->fwLink;     /*  <-----------把hLink再转回来  */
             p != ( hEnt* ) h;
             p = ( hEnt* )( (hLinks*)p )->fwLink )
        {
           printf("hData=[%d], key=[%s]\n", p->hData, p->key);
        }
    }

     

    main()
    {
       hLinks head;
       hEnt a[4];
       int i;

       head.bwLink = &head;
       head.fwLink = &head;

       for(i=0;i<4;i++)
       {
          a[i].hData = i*10;
          sprintf(a[i].key,"id=%d", i);

          /*  使用泛型算法构造双向链  */ 
          Insert( (hLinks *) &a[i], (hLinks *) &head ); /*   <-----注意这个强制转换  */
       }

       PrintLink( (hLinks *) &head ); /*   <-------也注意这个强制转换  */
    }

    其实,C++就是把C++翻译成C,再编译,所以编译好慢。我这里的这个动作可能类似C++转成C后的样子吧。大家多交流(litmouse@km169.net

    ————
    (版权所有,如需转载,请注明出处及作者)

    发表于 @ 2003年04月02日 09:02:00|评论(loading...)|编辑

    新一篇: 哈希表心得 | 旧一篇: 哈希表心得

    评论

    #linux内核中的面向对象思想 发表于2006-05-09 13:49:00  IP: 218.19.34.*
    在linux内核中,struct list_head 被嵌入在所有需要串接成双向队列的数据结构中,如 struct dentry,struct inode等。

    这些面向对象的思想在Linux内核中随处可见,特别是虚拟文件系统(VFS).
    #linux-2.6.0\include\linux\list.h 发表于2006-05-09 13:42:00  IP: 218.19.34.*
    #ifndef _LINUX_LIST_H
    #define _LINUX_LIST_H

    #ifdef __KERNEL__

    #include <linux/stddef.h>
    #include <linux/prefetch.h>
    #include <asm/system.h>

    /*
    * These are non-NULL pointers that will result in page faults
    * under normal circumstances, used to verify that nobody uses
    * non-initialized list entries.
    */
    #define LIST_POISON1 ((void *) 0x00100100)
    #define LIST_POISON2 ((void *) 0x00200200)

    /*
    * Simple doubly linked list implementation.
    *
    * Some of the internal functions ("__xxx") are useful when
    * manipulating whole lists rather than single entries, as
    * sometimes we already know the next/prev entries and we can
    * generate better code by using them directly rather than
    * using the generic single-entry routines.
    */

    struct list_head {
    struct list_head *next, *prev;
    };

    #define LIST_HEAD_INIT(name) { &(name), &(name) }

    #define LIST_HEAD(name) \
    struct list_head name = LIST_HEAD_INIT(name)

    #define INIT_LIST_HEAD(ptr) do { \
    (ptr)->next = (ptr); (ptr)->prev = (ptr); \
    } while (0)

    /*
    * Insert a new entry between two known consecutive entries.
    *
    * This is only for internal list manipulation where we know
    * the prev/next entries already!
    */
    static inline void __list_add(struct list_head *new,
    struct list_head *prev,
    #xmeng 发表于2007-08-31 10:23:59  IP: 218.249.141.*
    用内存实现继承,很棒

    但要注意在有些power pc下内存排列会有不同

    再这种情况下,不能用这种内存的继承
    发表评论  


    登录
    Csdn Blog version 3.1a
    Copyright © 陈皓