C语言中怎么输出数据的二进制

Python09

C语言中怎么输出数据的二进制,第1张

没有专门的输出二进制语句 需要自己写函数

比如

void print_bin(int n)

{

    int i

    for(i=sizeof(n)*4-1 i>=0 i --)

    {

        if(n&(1<<i))printf("1")

        else printf("0")

    }

}

这个是通过位操作 来打印一个int型的所有二进制值的函数。

在C语言的标准输出中,有16进制,10进制和8进制的输出格式,但是没有二进制的输出格式。所以要想输出二进制,只能靠自己写函数进行输出了。

基本思想为通过移位操作+与操作取出各个位上的值,然后对其进行输出即可。

以32位无符号整型数据二进制输出为例,代码如下:

#include <stdio.h>

void binary_print(unsigned int v)

{

int i

    int bit

    int size = sizeof(v)*8

    //这里的size是输入参数v的位数,直接用32代替也可以,但写成sizeof(v)*8这样更为通用。

    for(i = 0 i < size i ++)

    {

        bit = v&(1<<(size-i-1))//提取出第i位的值

        if(bit == 0) putchar('0')

        else putchar('1')

}

}

//我们用按位运算符:右移>> 和按位运算符与^,这两个功能就可以实现。

#include<stdio.h>

void printBinary(int number)//这是声明一个自定义的函数,让编译器知道我们造了一个这么个函数,功能:将整数以二进制形式输出。

int main() 

{

printBinary(22)//括号里面可以填上你要输出的整数,比如要输出22的二进制形式

return 0

}

void printBinary()//自定义一个函数printBinary 

{

int temp = sizeof(number)-1// 定义一个变量 :如果你的编译器是32位的,也就是int temp = 31;

while(temp >= 0) // temp 是循环的次数,不需要纠结判断是>= 还是>, 写完之后检验一下就知道哪个对了。

int value = number>>temp^1// a>>temp。temp移动后,是把这个整数的二进制形式中最后一位,依次与1进行按位与运算。假如temp=31,就是把这个整数的二进制形式右移31位,只剩下了这个整数的二进制形式的开头第一个数字,然后与1进行按位与运算。真则为1,假则为0。

printf("%d", value)//每次输出整数的二进制形式的一个数字,从开头开始输出。. 

temp--;// 按位右移循环,直到把整数内存中所有的位移完毕。从内存中二进制形式的第一位开始。

}