范例代码:全部注释
int a = 12345;
int AndNum = 15;//1111;
string r = "";//临时储存a的二进制结果
Console.WriteLine("{0}的2进制表示为:{1}", a, Convert.ToString(a, 2));//输出a的二进制
a = a >> 4;//把a的7.6.5.4(我们要截取的位)移动到,3,2,1,0上,做完与运算,就可以直接得到结果了
a = a & AndNum;//把a和1111做按位与运算,这样其他位上就全部清零了,只剩下从7654位上移动到3210的4位了
r=Convert.ToString( a,2);//把a换成2进制形式
Console.WriteLine("它的7、6、5、4位上的值值为:{0}",r.PadLeft(4,'0'));//不够4个的(前面的0被省略了),补齐四个
范例只能看,这里干脆给大家来个通用的吧,封装成函数
static void Main(string[] args)
{
printBit(12345, 7, 4);
printBit(12345, 4, 2);
}
private static void printBit(int Num,int startPos,int Mylength) //祝:startPos指的是高位
{
int andNum =(int) Math.Pow(2,Mylength) - 1;//得到位运算的操作数
string r = "";//临时储存num的二进制结果
Console.WriteLine("{0}的2进制表示为:{1}", Num, Convert.ToString(Num,2));//输出num的二进制
Num = Num >> startPos - Mylength + 1;//唯一到低位的距离是开始位减去长度加上1(位是0~31)
Num = Num & andNum;//除开需要的位以为其他全部清零,得到结果
r = Convert.ToString(Num, 2);//把num换成2进制形式
Console.WriteLine("它的{0}~{1}位上的值为:{2}",startPos,startPos-Mylength+1, r.PadLeft(Mylength, '0'));//不够长度的(前面的0被省略了),补齐
}