ASSCI码一共有127个,char却占了一c语言char占几个字节节,范围在0~128啊,差了一个是怎么回事啊?求大

如何把一个char型一个字节的数据转化为8个bit位的0~1,c语言实现怎么实现_百度知道
如何把一个char型一个字节的数据转化为8个bit位的0~1,c语言实现怎么实现
void convert(char c){char result[8]={0};for(int i=0;i&8;i++)
result[i]=c&(0x01&&i);}
其他类似问题
为您推荐:
c语言的相关知识
等待您来回答
下载知道APP
随时随地咨询
出门在外也不愁帮我看一个C51流水灯的程序,看看为什么我总是跑到128步就从头跑了,应该有144步。_百度知道
帮我看一个C51流水灯的程序,看看为什么我总是跑到128步就从头跑了,应该有144步。
0xff,0xf0,0x24!穷人没多少分,0x24,0x24; 0,0x24,0xff,0xf0,0x7f,0xfc,0x0,0x7f,0xff,0xff,0xf8;
P3 = 255,0xff,0xfe,0x0,0xff,0x7f,0x7f,0xe0,0xfc,0x7f,0x7c,0x24,0xff,0x92,0x3e,0xff,0x0,0stc11,0xfe!,0x7f,0x7f,0x7f,0x92,0xfc,0x0,0x7f,0xff, y,0x0,0 0,0x7f,0xff,0x0,0x7c,0x7f,0x7f,0x0,0xf8,0x3e.h&gt,0xff,0x0,0x7f,0xfc,0xfc,0x7f,0x7f,0x0,0x0,0x7f,0x7c},0x7f,0xff,0x7c,0x7f,0xc0,怎么总是在128步就从头跑了,0x7f;}void main(){
char i = 0,0xfc,0xc0,0xf8;sfr m1 = 0x92,0xe0,0x24,0xfc,0x7f,0x7f,0xff,0x7f,0x7f,0xfe,0x7f;
for(x = z,0x0,0x7f,0x0,0x80,0x0;char code DISP0[] = {0x0,0x92,0xff,0x7c,0x0,谁帮我看看,0x7f,0xff,0x7f,0xf8,0xfe!=0)
P3 = DISP1[i] ,0x--)
for(y = 200,0x0!,0x7c,0xfc,0x0,0x7f,0xfe,0x0,0xff,0x7f,0x3c,0x7f,0x0,0x7f; x &gt,0x7e,0x7e,0x49,0x7f;sfr m2 = 0xb2,0xff,0xff,0xff,0x0,0x24,0xf8,0x0},0x49,0xfc,0x49;sbit k1= P3^4,0xc0!,0xfc,0x7f,0x80,0xff,0xff,0x49;
} }上面就是程序了,0x7e,0xff,0xfe,0x3e,0x7f,0x7f,0x80,0x7c,0xff,0xff,0x0,0x7f,0x7f,0x3c,0x7f,0x7f,0xff,0xff,0x92,0x7f,0xff,应该144步呀,0x92,0x49,0x7f,0x7f,0x7f,0x3c,0
m1 =0xff,0xff,0x7f;delay_ms(int z){
int x,0x3c; i++,0xf8,0x3c,一个简单的流水灯,0xff,0x7f,0xff,0x0,0x7f,0xfc,0x7c,0
if (i==144)
i = 0,0x0;
m2 =0xff,0x3e,0x0,0xe0,0x7f,0xff,0x3c,0x0,0x80,0x0,0xff,0xfe,0x7f,0xff!=0)
P1 = DISP0[i] ,0x3e,0xc0,0xff,0x7c;
delay_ms(200),0x0,0x24,0x7c,0x24,0 y &gt,0xe0,0xff,0xf0,0x0,0x7f,0x0,0x0,0x7f,0xff,0x7f,0xff,0x0;
P1 = 255,0xe0,0x7f,0xff,0x7f,0x92,0x0,0x7f;
while(1) {
if (k1,0x7f,0
if (k1,0x7f,0x7c,0x7f,0x7c,0xff,0x7f,0 y--),0x49,0x7f,0x80,0x7f,0x7f,0x7f,0xfe,0x92,0x80,0x3e,0x0,0x7f,0xff,0x7f,0x7c,0x7f,0x7f,0x3e,0xff,0xff,0x7f,0xf0,感激不尽,0xff,0x0,0xf0,0x0,0xff,0x0,0x3c,0x7c,0x7f,0x49,0x3e,0x0,0xff,0xff,0x0,0x7f,0xc0,0x7f,0xc0,0x7f;char code DISP1[] = {0x7f,0x92,0x92,0xe0,0xff,0x3c,0x0,0x7c,0x0,0x7c,0xf0,0x49,0xff,0x7f,0x0,0xff,0x7f,0x49,0x0,0x7f,0x0,0xff!#include&lt
提问者采纳
这个是有符号变量, 最大只有127定义成下面这样就对了 unsigned char i=0char i = 0;上面这行定义错了
提问者评价
按照你说的,真的成功了,好开心,谢谢你!
其他类似问题
为您推荐:
其他2条回答
一楼说的也有道理,不过我们从来没有遇到过这样的问题,一般在开头就定义了用uchar=unsigned char
#include&stc11.h&
sfr m1 = 0x92;
sfr m2 = 0xb2;
sbit k1= P3^4;
char code DISP0[] = {0x0,0x80,0xc0,0xe0,0xf0,0xf8,0xfc,0xfe,0xff,0xff,0xff,0xff,0xff,0xfe,0xfc,0xf8,0xf0,0xe0,0xc0,0x80,0x0,0x0,0x0,0x0,0x80,0xc0,0xe0,0xf0,0xf8,0xfc,0xfe,0xff,0xff,0xff,0xff,0xff,0xfe,0xfc,0xf8,0xf0,0xe0,0xc0,0x80,0x0,0x0,0x0,0x0,0x80,0xc0,0xe0,0xf0,0xf8,0xfc,0xfe,0xff,0xff,0xff,0xff,0xff,0xfe,0xfc,0xf8,0xf0,0xe0,0xc0,0x80,0x0,0x0,0x0,0x92,0x49,0x24,0x92,0x49,0x24,0x92,0x49,0x24,0x92,0x49,0x24,0x92,0x49,0x24,0x92,0x49,0x24,0x92,0x49,0x24,0x92,0x49,0x24,0x92,0x49,0x24,0xff,0x0,0xff,0x0,0xff,0x0,0xff,0x0,0xff,0x0,0xff,0x0,0xff,0x0,0xff,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,0x0,...
等待您来回答
下载知道APP
随时随地咨询
出门在外也不愁9248人阅读
c语言(29)
&&&& 在C语言中, signed char 类型的范围为-128~127,每本教科书上也这么写,但是没有哪一本书上(包括老师)也不会给你为什么是-128~127,这个问题貌似看起来也很简单容易, 以至于不用去思考为什么,不是有一个整型范围的公式吗:& -2^(n-1)~2^(n-1)-1&& n为整型的内存占用位数,所以int类型32位 那么就是 -(2^31)~2^31 -1 即
&& -~,但是为什么最小负数绝对值总比最大正数多1 ,这个问题甚至有的工作几年的程序员都模棱两可,因为没有深入思考过,只知道书上这么写。。于是,我不得不深入思考一下这个被许多人忽视的问题。。
&&& 对于无符号整数,很简单,全部位都表示数值,比如 char型,8位,用二进制表示为 ~
最大即为十进制255,所以 unsigned char 的范围为0~ 255,在这里普及一下2进制转十进制的方法, 二进制每一位的数值乘以它的位权(2^(n-1),n为自右向左的位),再相加,可得到十进制数,比如 :
1111 ^7+1*2^6+1*2^5+1*2^4+1*2^3+1*2^2+1*2^1+1*2^0=127& 。
&& 但是对于有符号整数,二进制的最高位表示正负,不表示数值,最高位为0时表示正数,为1时表示负数,这样一来,能表示数值的就剩下(n-1)位了,比如 char&a= -1;&&&那么二进制表示就为&1 0000001,& 1 表示为0 0000001 ,所以signed char 型除去符号位剩下的7位最大为1111
111 =127,再把符号加上,0
,1 1111111= -127,范围应该为 -127~127 ,同理int类型也一样,但是问题出来了,教科书上是-128~127 啊,下面就剖析一下这个惊人的奇葩。。。
&&& 再普及一下计算机内部整数存储形式,大家都知道计算机内部是以二进制来存贮数值的,无符号整数会用全部为来存储,有符号的整数,最高位当做符号位 ,其余为表示数值,这样貌似合理, 却带来一个麻烦,当进行加法时,1+1
—————————
&&&&&&& && ………………2&
当相减时 1-1=?& 由于计算机只会加法不会减法,它会转化为1+(-1) ,因此
____________________
&&&&&&&&&&&&&& …………… -2&&& ,1-1= -2?& 这显然是不对了,所以为了避免减法运算错误,计算机大神们发明出了反码,直接用最高位表示符号位的叫做原码, 上面提到的二进制都是原码形式,反码是原码除最高位其余位取反,规定:正数的反码和原码相同,负数的反码是原码除了符号位,其余为都取反,因此-1
的源码为 1 0000001 ,反码为 1 1111110, 现在再用反码来计算 1+(-1)
————————
&&&&&&&&&&&& …………再转化为原码就是
= -0& ,虽然反码解决了相减的问题,却又带来一个问题,-0 ,既然 表示 0,那么就没有 -0 的必要, 出现 +0= -0=0 ,一个0 就够了,为了避免两个0的问题,计算机大师们又发明了补码,补码规定: 整数的补码是其本身,负数的补码为其反码加一 ,所以,负数转化为反码需两个步骤,
第一,先转化为反码,第二: 把反码加一。。这样 -1 的补码为 &&& ,1+(-1)
________________
&&1 && ……………………& 这里变成了9位,由于char 为8位,最高位1 被丢弃 结果为0 ,运算正确
&&再看, -0 :原码
,由于char 是 八位 ,所以取低八位,&& +0 :原码为&,补码为也为
,虽然补码0都是相同的,但是有两个0 ,既然有两个0 ,况且0既不是正数,也不是负数,&用原码为 表示就行了,&这样一来,有符号的char&,原码都用来表示-127~127
之间的数了,唯独剩下原码 没有用,用排列组合也可以算出来,0???????,能表示2^7=128个数,刚好是0~127, 1???????,也能表示128个数,总共signed char 有256 个数,这与-127~127 中间是两个0 刚好吻合。。现在再来探讨一下关于剩下的那个,
既然-127 ~0~ 127都有相应的原码与其对应,那么 表示什么呢,当然是-128了,为什么是-128呢,网上有人说-0即 与128的补码相同,所以用表示-128,,这我实在是不敢苟同,或者说-128没有原码,只有补码,胡扯,既然没有原码何来补码,还有说-128的原码与-0(1000
0000)的原码相同,所以可以用表示-128,我只能说,回答的不要那么牵强, 原码 与-128的原码实际上是不同的, 但为什么能用它表示-128进行运算,如果不要限制为char 型(即不要限定是8位),再来看,-128的原码:1
,9位,最高位符号位,再算它的反码:1
,进而,补码为: <span style="color:#ff0 0000,这是-128的补码,发现和原码一样, 1 和 相同?如果说一样的人真是瞎了&#30524;了,所以,-128的原码和-0()的原码是不同的,但是在char 型中,是可以用 表示-128的,关键在于char 是8位,它把-128的最高位符号位1 丢弃了,截断后-128的原码为1000
000 和-0的原码相同,也就是说
<span style="color:#ff 0000& 和-128丢弃最高位后余下的8位相同,所以才可以用-0 表示-128,这样,当初剩余的-0(),被拿来表示截断后的-128,因为即使截断后的-128和char 型范围的其他数(-127~127)运算也不会影响结果, 所以才敢这么表示-128。
&& 比如 -128&#43;(-1)
&&&& & ------------------丢弃最高位的-128
&#43;&&&&&&& -----------------&& -1
________________
&&&1&&& ------------------char 取八位,这样结果不正确,不过没关系 ,结果-129本来就超出char型了,当然不能表示了。
&&& 比如 -128&#43;127
————————
--------------& -1 结果正确, 所以,这就是为什么能用 表示-128的原因。
& 从而也是为什么char 是-128~127,而不是-127~127 ,short int 同样如此 -& 因为在16位中,-32768为原码为17位,丢弃最高位剩下的16为- 0 的原码相同。。。。
&&&& 还有一个问题:
&&&& 既然-128最高位丢弃了。那么
&&&& char a=-128;& //在内存中以补码1
存储,但由于是char ,所以只存储
&&&& printf(&%d&,a); //既然最高位丢弃了,输出时应该是 的原码的十进制数-0 ,但为什么能输出-128呢。
&&&&&还能打印出-128;
&&&& 我猜想是计算机内部的一个约定,就像float一样 ,能用23位表示24位的精度 ,因为最高位默认为1,到时候把23位取出再加 1便可。
&&& -128也是同样的原理,当数据总线从内存中取出的是 ,CPU会给它再添最高一位,变为1
这样才能转化为
&& -128输出,不然 如何输出?这当然是我的一种推断,具体怎么实现还得问CPU的设计者了。。。。
&&&& 再看一个例子:
&&&&& char a=-129;
&&&&& printf(&%d&,a)& ;&&& 会输入多少??&&& 结果为127 ,为什么呢?&
&&&&& -129在补码为10
只取后八位存储,即
这个&#20540;刚好是127了,同理-130 截断后为126.....
如此按模轮回,关于模就先不探讨了。。
&&&&& 那么
&&&&& unsigned& char a=& -1;
&&&& if( 1&a)&& printf(&大于&);
&&&&& else&&
&&&&&&&&& printf(&小于&);
&&&&& 结果是什么呢?& 出人意料的是:& 小于,而不是大于,猫腻在你哪呢,还是存储问题:
&&&& a为unsigned 无符号, 它的八位都用来存储数&#20540;, 没有符号位,编译器把 -1 转换为补码为 ,但由于是无符号,计算机会把
当做是无符号来对待 ,自然就是 2^8 -1& = 255 了,所以相当于是if( 1&255) 肯定是
&printf(&小于&);了。。。
&&&&& 。。。。。。。。。。。
&&&& 好了,就说到这儿吧。。。。。。。。
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
访问:183785次
积分:2118
积分:2118
排名:第10724名
原创:52篇
转载:57篇
评论:37条
(20)(7)(1)(3)(1)(1)(4)(2)(1)(1)(9)(1)(19)(3)(23)(3)(10)Char能把字符以Ascll码的形式表示0~127。 但从128开始就没有对应的字符了_百度知道
Char能把字符以Ascll码的形式表示0~127。 但从128开始就没有对应的字符了
Char能把字符以Ascll码的形式表示0~127。
但从128开始就没有对应的字符了 unsigned char 如何表示128~256的数字呢? 可能我的理解有问题 希望能带点例子最好
您的回答被采纳后将获得:
系统奖励20(财富值+经验值)+难题奖励10(财富值+经验值)+提问者悬赏10(财富值+经验值)
我有更好的答案
/&#47,因为八位表示255;&#47;因为最高一位是符号位表示127;/只能表示-128~-1吧.能表示0~255unsigned char a
其他类似问题
为您推荐:
ascll的相关知识
等待您来回答
下载知道APP
随时随地咨询
出门在外也不愁

我要回帖

更多关于 char 字节 的文章

 

随机推荐