strpbrk 函数解析

本文详细解析了strpbrk函数的工作原理,通过一个32字符大小的map来映射ASCII字符,并通过位运算实现字符查找。文章介绍了如何初始化map,设置控制字符以及如何在map中查找目标字符的过程。
摘要由CSDN通过智能技术生成

一、           Strpbrk (string pointer break)

 

//
// 函 数: char * strpbrk(const char * string,const char * control)
// 功 能: 检查字符串string和control中第一个相同的字符 
// 参 数: 
// 返 回: 返回字符串string和control中第一个相同的字符后面的string字符串
//

char * strpbrk(const char * string,const char * control)
{  
     const char * str = (const char *)string;  
     const char * ctrl = (const char *)control;  

     unsigned char map[32];  

     int count = 0;  

     /*clear the map*/  
     memset(map,0,32*sizeof(unsigned char));  

     /*set bits in control map*/ 
     while( *ctrl ) 
    {  

         map[*ctrl >> 3] |= (0x01 << (*ctrl & 7));  

         ctrl++; 
    }   

    while ( *str )
    {

         if (map[*str >> 3] & (1 << (*str & 7)))
         {

             return((char *)str);
         }

         str++;
    }

    return(NULL);

}
 
//
// 例:string  = "129th";  
//     control = "b295";
//

仔细体会下上面的代码,不禁暗暗叫绝。

1、  首先定义个大小为32个字符的map,为什么要这么划一道呢?因为在ASCII表能表示128个字符,而扩展后的ASCII却能表示256</

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值