将char转换为c中的二进制
我试图将角色转换为其二进制表示(因此字符 - > ascii hex - >二进制)。
我知道要做,我需要移动和和
。但是,由于某种原因,我的代码无法正常工作。
这是我拥有的。 *temp
指向C字符串中的索引。
char c;
int j;
for (j = i-1; j >= ptrPos; j--) {
char x = *temp;
c = (x >> i) & 1;
printf("%d\n", c);
temp--;
}
I am trying to convert a character to its binary representation (so character --> ascii hex --> binary).
I know to do that I need to shift and AND
. However, my code is not working for some reason.
Here is what I have. *temp
points to an index in a C string.
char c;
int j;
for (j = i-1; j >= ptrPos; j--) {
char x = *temp;
c = (x >> i) & 1;
printf("%d\n", c);
temp--;
}
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
我们显示了两个将单个字符打印到二进制的功能。
PrintBinchar(10)将写入控制台
ITOA是一个库函数,可将单个整数值转换为带有指定基础的字符串。
例如,ITOA(1341,输出,10)将在输出字符串“ 1341”中写入。
当然,ITOA(9,输出,2)将在输出字符串“ 1001”中写入。
下一个功能将打印到标准输出字符的完整二进制表示形式中,即,如果较高的位为零,它将打印所有8位。
printbincharpad(10)现在将写入控制台
,现在我提出了一个打印整个字符串(没有最后一个null字符)的函数。
但是,请考虑ITOA不会添加填充零,因此PrintStringasbinary(“ AB1”)会打印出类似的内容:
We show up two functions that prints a SINGLE character to binary.
printbinchar(10) will write into the console
itoa is a library function that converts a single integer value to a string with the specified base.
For example... itoa(1341, output, 10) will write in output string "1341".
And of course itoa(9, output, 2) will write in the output string "1001".
The next function will print into the standard output the full binary representation of a character, that is, it will print all 8 bits, also if the higher bits are zero.
printbincharpad(10) will write into the console
Now i present a function that prints out an entire string (without last null character).
Consider however that itoa don't adds padding zeroes, so printstringasbinary("AB1") will print something like:
说明:
在每次迭代时,通过将其移动并与1进行比较,从字节中读取了最重要的位
。
将其转移7将给出0000 0001,因此得出结论,最重要的位是1。0000 0001& 1 = 1。这是第一个在控制台中打印的位。接下来的迭代将导致0 ... 0。
Explanation:
With every iteration, the most significant bit is being read from the byte by shifting it and binary comparing with 1.
For example, let's assume that input value is 128, what binary translates to 1000 0000.
Shifting it by 7 will give 0000 0001, so it concludes that the most significant bit was 1. 0000 0001 & 1 = 1. That's the first bit to print in the console. Next iterations will result in 0 ... 0.
您的代码非常模糊,无法理解,但是我可以为您提供替代方案。
首先,如果您想要
temp
要浏览整个字符串,则可以执行类似的操作:术语
*temp
作为的条件只需检查您是否已达到字符串的末端。如果有的话,
结束的*temp
将为'\ 0'
(nul
)和。
现在,在for内部,您想找到构成
*temp
的位。假设我们打印了一些位:要使它更通用,即将任何类型转换为位,您可以将
bit_index = 7
更改为bit_index = sizeof(*temp)* 8-1
Your code is very vague and not understandable, but I can provide you with an alternative.
First of all, if you want
temp
to go through the whole string, you can do something like this:The term
*temp
as thefor
condition simply checks whether you have reached the end of the string or not. If you have,*temp
will be'\0'
(NUL
) and thefor
ends.Now, inside the for, you want to find the bits that compose
*temp
. Let's say we print the bits:To make it a bit more generic, that is to convert any type to bits, you can change the
bit_index = 7
tobit_index = sizeof(*temp)*8-1