大佬教程收集整理的这篇文章主要介绍了c – 在现代x86硬件上编写比特流的最快方式,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
void write_bits(someContainer<unsigned int>& dst,unsigned int& buffer,unsigned int& bits_left_in_buffer,int codeword,short bits_to_writE){ if(bits_to_write < bits_left_in_buffer){ buffer|= codeword << (32-bits_left_in_buffer); bits_left_in_buffer -= bits_to_write; }else{ unsigned int full_bits = bits_to_write - bits_left_in_buffer; unsigned int towrite = buffer|(codeword<<(32-bits_left_in_buffer)); buffer= full_bits ? (codeword >> bits_left_in_buffer) : 0; dst.push_BACk(towritE); bits_left_in_buffer = 32-full_bits; } }
有没有人知道任何好的优化,快速说明或其他可能有用的信息?
干杯,
@H_450_8@unsigned char* membuff; unsigned bit_pos; // current BIT position in the buffer,so it's max size is 512Mb // input bit buffer: we'll decode the byte address so that it's even,and the DWORD from that address will surely have at least 17 free bits inline unsigned int ge@R_262_11164@its(unsigned int bit_cnt){ // bit_cnt MUST be in range 0..17 unsigned int byte_offset = bit_pos >> 3; byte_offset &= ~1; // rounding down by 2. unsigned int bits = *(unsigned int*)(membuff + byte_offset); bits >>= bit_pos & 0xF; bit_pos += bit_cnt; return bits & BIT_MASKS[bit_cnt]; }; // output buffer,the whole desTination should be memset'ed to 0 inline unsigned int pu@R_262_11164@its(unsigned int val,unsigned int bit_cnt){ unsigned int byte_offset = bit_pos >> 3; byte_offset &= ~1; *(unsigned int*)(membuff + byte_offset) |= val << (bit_pos & 0xf); bit_pos += bit_cnt; };@H_450_8@ @H_450_8@
以上是大佬教程为你收集整理的c – 在现代x86硬件上编写比特流的最快方式全部内容,希望文章能够帮你解决c – 在现代x86硬件上编写比特流的最快方式所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。