栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

位掩码的大小有实际限制吗?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

位掩码的大小有实际限制吗?

在我脑海中,我写了一个

set_bit
and
get_bit
函数,它可以使用字节数组和数组中的位偏移量,并使用一些位扭曲来设置/获取数组中的适当位。像这样的东西(用C语言编写,但希望您能理解):

// sets the n-th bit in |bytes|. num_bytes is the number of bytes in the array// result is 0 on success, non-zero on failure (offset out-of-bounds)int set_bit(char* bytes, unsigned long num_bytes, unsigned long offset){  // make sure offset is valid  if(offset < 0 || offset > (num_bytes<<3)-1) { return -1; }  //set the right bit  bytes[offset >> 3] |= (1 << (offset & 0x7));  return 0; //success }//gets the n-th bit in |bytes|. num_bytes is the number of bytes in the array// returns (-1) on error, 0 if bit is "off", positive number if "on"int get_bit(char* bytes, unsigned long num_bytes, unsigned long offset){  // make sure offset is valid  if(offset < 0 || offset > (num_bytes<<3)-1) { return -1; }  //get the right bit  return (bytes[offset >> 3] & (1 << (offset & 0x7));}


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/414687.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号