freshbug's notes

freshbug的代码人生

bekilledlzyID:bekilledlzy
14118次访问,排名7790(-1)好友0人,关注者0
bekilledlzy的文章
原创 17 篇
翻译 0 篇
转载 32 篇
评论 6 篇
freshbug的公告
访问www.freshbug.com
自2007年10月16日
freshbug的联系方式:
freshbug@gmail.com
最近评论
loadend:你好,我想问一下,那注册google ad帐户的时候不是要填网址嘛,填什么呢?是不是填http://blog.csdn.net/用户名/??
freshbug:stl里面有一些静态变量 不能跨dll vector有时候能跨dll是因为连续的内存分布

跨模块传输数据最好是能用C风格的结构 用C++类很容易出问题
wang:我是向dll中传一个map指针,结果也是it++之后就内存泄漏
wang:我也遇到了类似问题。
远离尘嚣:老大,能把你的Uft8ToAnsi是自定义的转码函数共享一下嘛?万分感谢!
文章分类
收藏
    相册
    who's freshbug?
    技术站点
    老牛们的blog
    咨讯
    存档
    软件项目交易
    订阅我的博客
    XML聚合  FeedSky
    订阅到鲜果
    订阅到Google
    订阅到抓虾
    订阅到BlogLines
    订阅到Yahoo
    订阅到GouGou
    订阅到飞鸽
    订阅到Rojo
    订阅到newsgator
    订阅到netvibes

    转载 c++效率,函数指针收藏

    新一篇: 病例:不理解C/C++的函数指针 | 旧一篇: P2P的NAT研究

    c++效率,函数指针...- -

                                          

    C++中函数指针数组的妙用

       笔者在开发某软件过程中遇到这样一个问题,前级模块传给我二进制数据,输入参数为 char* buffer和 int length,buffer是数据的首地址,length表示这批数据的长度。数据的特点是:长度不定,类型不定,由第一个字节(buffer[0])标 识该数据的类型,共有256(28 )种可能性。我的任务是必须对每一种可能出现的数据类型都要作处理,并且我的模块包含若干个函数,在每个函数里面都要作类似的处理。若按通常做法,会写出 如下代码:

    void MyFuntion( char* buffer, int length )
    {
        __int8 nStreamType = buffer[0];
       tch( nStreamType )
        {
           case 0:
               function1();
               break;
           case 1:
           ......
           case 255:
               function255();
               break;
         }
    }

      如果按照这种方法写下去,那么在我的每一个函数里面,都必须作如此多的判断,写出的代码肯定很长,并且每一次处理,都要作许多次判断之后才找到正确的处理函数,代码的执行效率也不高。针对上述问题,我想到了用函数指针数组的方法解决这个问题。

      函数指针的概念,在潭浩强先生的C语言程序设计这本经典的教程中提及过,在大多数情况下我们使用不到,也忽略了它的存在。函数名实际上也是一种指针,指向函数的入口地址,但它又不同于普通的如int*、double*指针,看下面的例子来理解函数指针的概念:
    1 int funtion( int x, int y );
    2 void main ( void )
     {
    3    int (*fun) ( int x, int y );
    4    int a = 10, b = 20;
    5    function( a, b );
    6    fun = function;
    7    (*fun)( a, b );
    8     ……
      }
       语句1定义了一个函数function,其输入为两个整型数,返回也为一个整型数(输入参数和返回值可为其它任何数据类型);语句3定义了一个函数指 针,与int*或double*定义指针不同的是,函数指针的定义必须同时指出输入参数,表明这是一个函数指针,并且*fun也必须用一对括号括起来;语 句6将函数指针赋值为funtion,前提条件是*fun和function的输入参数和返回值必须保持一致。语句5直接调用函数function(), 语句7是调用函数指针,二者等效。

      当然从 上述例子看不出函数指针的优点,目的主要是想引出函数指针数组的概念。我们从上面例子可以得知,既然函数名可以通过函数指针加以保存,那们也一定能定义一 个数组保存若干个函数名,这就是函数指针数组。正确使用函数指针数组的前提条件是,这若干个需要通过函数指针数组保存的函数必须有相同的输入、输出值。

    这样,我工作中所面临的问题可以解决如下:
    首先定义256个处理函数(及其实现)。
    void funtion0( void );
    ……..
    void funtion255(void );
    其次定义函数指针数组,并给数组赋值。
    void (*fun[256])(void);
    fun[0] = function0;
    …….
    fun[255] = function();
    最后,MyFunction()函数可以修改如下:

    void MyFuntion( char* buffer, int length )
    {
        __int8 nStreamType = buffer[0];
        (*fun[nStreamType])();
    }

      只要2行代码,就完成了256条case语句要做的事,减少了编写代码时工作量,将nStreamType作为数组下标,直接调用函数指针,从代码执行效率上来说,也比case语句高。假如多个函数中均要作如此处理,函数指针数组更能体现出它的优势。

     

    发表于 @ 2007年08月22日 17:30:00|评论(loading...)|编辑

    新一篇: 病例:不理解C/C++的函数指针 | 旧一篇: P2P的NAT研究

    评论:没有评论。

    发表评论  


    登录
    Csdn Blog version 3.1a
    Copyright © freshbug