/************************************************************
将两个字符转换为一个字节,由于基本类型范围的影响,
其中包含了一种巧合即当_2asc_to_1b这个函数在转换例子中的"e1"时,
能够转换成功,因为e0转换完是2e0,由于超出了unsigned char的范围,
2将被丢弃,正好是e0.
*************************************************************/
#include <stdio.h>
unsigned char _2asc_to_1b(unsigned char* buff)
{
unsigned char b2,b1;
b2 = *(buff);
if(b2<=0x39)
b1=(b2-0x30)<<4;
else
b1=(b2-0x41+10)<<4;
b2 = *(buff+1);
if(b2<=0x39)
b1+=(b2-0x30);
else
b1+=(b2-0x41+10);
return b1;
}
unsigned char my_2asc_to_1b(unsigned char* buff)
{
unsigned char b2,b1;
b2 = *(buff);
if(b2<=0x39)
b1=(b2-0x30)<<4;
else
b1=(b2-0x61+10)<<4;
b2 = *(buff+1);
if(b2<=0x39)
b1+=(b2-0x30);
else
b1+=(b2-0x61+10);
return b1;
}
int main(int argc, char *argv[])
{
char *str = "10e1";
char *str1 = "ed6a";
unsigned char tar1[4] = {0};
unsigned char tar2[4] = {0};
printf("str:%s str1:%s\n",str,str1);
tar1[0] = _2asc_to_1b(str);
tar1[1] = _2asc_to_1b(str+2);
tar1[2] = _2asc_to_1b(str1);
tar1[3] = _2asc_to_1b(str1+2);
printf("_2asc:%02x%02x %02x%02x\n",tar1[0],tar1[1],tar1[2],tar1[3]);
tar2[0] = my_2asc_to_1b(str);
tar2[1] = my_2asc_to_1b(str+2);
tar2[2] = my_2asc_to_1b(str1);
tar2[3] = my_2asc_to_1b(str1+2);
printf("my_sc:%02x%02x %02x%02x\n",tar2[0],tar2[1],tar2[2],tar2[3]);
}
相关文章
- byte数组转blob类型,如何将字节数组转换为Blob
- 为什么使用eval()将json字符串转换为对象要多加一个小括号
- c语言 位运算符与赋值运算符可以组成复合赋值运算符;例如 a << =2相当于a = a << 2 1、左移运算符(< 左移运算符是用来将一个数的各二进制位左移若干位,移动的位数由右操作数指定(右操作数必须是非负值),其右边空出的位用0填补,高位左移溢出则舍弃该高位。 例如:将a的二进制数左移2位,右边空出的位补0,左边溢出的位舍弃。 若a=15,即00001111(2),左移2,位得00111100(2)。 左移1位相当于该数乘以2,左移2位相当于该数乘以2*2=4,15<<2=60,即乘了4。但此结论只适用于该数左移时被溢出舍弃的高位中不包含1的情况。 假设以一个字节(8位)存一个整数,若a为无符号整型变量,则a=64时,左移一位时溢出的是0,而左移2位时,溢出的高位中包含1。 2、右移运算符(>>) 右移运算符是用来将一个数的各二进制位右移若干位,移动的位数由右操作数指定(右操作数必须是非负值),移到右端的低位被舍弃,对于无符号数,高位补0。对于有符号数,某些机器将对左边空出的部分用符号位填补(即“算术移位”),而另一些机器则对左边空出的部分用0填补(即“逻辑移位”)。 注意:对无符号数,右移时左边高位移入0;对于有符号的值,如果原来符号位为0(该数为正),则左边也是移入0。如果符号位原来为1(即负数),则左边移入0还是1,要取决于所用的计算机系统。有的系统移入0,有的系统移入1。移入0的称为“逻辑移位”,即简单移位;移入1的称为“算术移位”。 例: a的值是八进制数113755: a:1001011111101101 (用二进制形式表示) a>>1: 0100101111110110 (逻辑右移时) a>>1: 1100101111110110 (算术右移时) 在有些系统中,a>>1得八进制数045766,而在另一些系统上可能得到的是145766。Turbo C和其他一些C 编译采用的是算术右移,即对有符号数右移时,如果符号位原来为1,左面移入高位的是1。 拓展资料 运算符含义描述 & 按位与 如果两个相应的二进制位都为1,则该位的结果值为1,否则为0 | 按位或 两个相应的二进制位中只要有一个为1,该位的结果值为1 ^ 按位异或 若参加运算的两个二进制位值相同则为0,否则为1 ~ 取反 ~是一元运算符,用来对一个二进制数按位取反,即将0变1,将1变0 << 左移 用来将一个数的各二进制位全部左移N位,右补0 >> 右移 将一个数的各二进制位右移N位,移到右端的低位被舍弃,对于无符号数,高位补0
- float([x]): 将一个字符串或数转换为浮点数。如果无参数将返回0.0
- 贝贝有疑:char为什么能存两个字节,却只能存一个字符?
- 写一个函数,将两个字符串连接
- C#返回字符串的字节长度,一个中文算两个字符的代码
- (后端)JackSon将java对象转换为JSON字符串(转)
- 如何将UTF-8字节[]转换为字符串?
- 当我将一个字节数组从Swift转换为Objective-C时应该使用什么数据类型