1.什么叫原码、无符无符反码、号变后的号变后补码、成有成和原码、符号符号反码、源码源码补码
2.C#移ä½è¿ç®
3.嵌入式问题
什么叫原码、反码、号变后的号变后补码、成有成和原码、符号符号反码、源码源码补码
正数的无符无符原码、反码、号变后的号变后补码相同;
负数的成有成原码取反就是反码(最高位1不能变),反码+1就是符号符号补码;
负数的补码取反就是反码(最高位1不能变),反码+1就是源码源码原码;
因为最高bit不是1,所以这里Y一定是正整数。
如果X是canmake溯源码无符号数:
X和Y的补码就是源码,直接相减的到结果是整数,也是补码,
X-Y=
如果X是有符号数:
X的原码是,即-,Y的原码是,即,X-Y为-,得到的培训行业源码原码,对应的补码是
C#移ä½è¿ç®
移ä½è¿ç®(shifting operationï¼æ¯C#ä¸ä¸ç§ç¹æ®çè¿ç®ï¼å ¶åçæ¯æ ¹æ®æ°å¼åå¨å¨è®¡ç®æºå åä¸ä»¥äºè¿å¶çæ åï¼è¿è¡å移æè å移è¥å¹²ä½çç®æ³ãæ ¹æ®é¢ç®æ¥çï¼æ 符å·ä½çæ°å移å¨âå·¦âãâå³âæ以ä¸è§å¾ï¼
1ï¼å·¦ç§»ï¼å°æ¯ä¸ªäºè¿å¶çæ°åå¾å·¦è¾¹ç§»å¨è¥å¹²ä½ï¼è¥å¹²ä½ï¼ç¬¦å·â<<âåé¢çæ°åï¼ä¸è¶³ä»¥0è¡¥å ï¼ã
2ï¼å³ç§»ï¼å°æ¯ä¸ªäºè¿å¶çæ°åå¾å³è¾¹ç§»å¨è¥å¹²ä½ï¼è¥å¹²ä½ï¼ç¬¦å·â>>âåé¢çæ°åï¼ä¸è¶³ä»¥æé«ä½çæ°åè¡¥å ï¼ã
ä¸é¢ç»åºå ·ä½ä¾åï¼
ãä¾ã计ç®2<<2å2>>2ï¼
å¨è®¡ç®æºä¸ï¼æ£æ´æ°2çæºç ï¼åç ï¼è¡¥ç ï¼ ï¼å¾å·¦è¾¹æ¯ä¸ªæ°å移å¨2ä½ä¹åï¼æé«ç两ä½æº¢åºï¼ä¸¢å¼ï¼ï¼åå 为符å·ä½ï¼æé«ä½ä¸º0ï¼ï¼å æ¤è¡¥å 两个0ï¼åæ =>8.
åä¹ï¼ å³ç§»å¨2为å»æå³è¾¹ç两个æ°åï¼å¨æé«ä½ä¸æ·»å 两个0ï¼åæ =>0
ãéè¦ç»è®ºã
1ï¼å·¦ç§»åå³ç§»nä½ï¼ç¸å½äºå»æåé¢ååé¢å¯¹åºçè¥å¹²ä½ï¼åè¡¥å ã
2ï¼å½å·¦ç§»å¨æ¯2çæ¶åï¼å¯ä»¥çææ¯æ个æ°Ã2çn次æ¹ï¼åä¹é¤ä»¥2çn次æ¹ã
嵌入式问题
1.us1为 us2为 首先us1和us2是无符号形短整数,而你赋值的时候用的是负数,无符号形和普通短整数都是2个字节有符号形用的是补码表示的,而无符号形直接用无符号的原码,范围是0-(原码是一个数直接化成二进制的数,没有符号第一位是符号位。补码是源码的每位取反再加1,计算机中用补码主要是springboot源码之家为了让硬件设计方便,这个是基础,所以不多说了)所以你的负数先变成补码-=,把-的补码存到内存中,而你的声明是无符号形短整数,所以使用它的时候就把它当无符号型整数的。unsigned是无符号的意思表示正整数,short int可以表示负数,用补码表示。红警源码 csdn
2。 *=
3。if(si1<0)就是说如果si1是负数就执行下面的一个语句,或一个花括号里面的所有语句,由于你的si1是-就会执行{ ui-=(*(unsigned short *)&si2&(~(1L<<)))<<;cout<<ui<<endl;}如果你在这句用的是us1,由于us1是无符号型整数,所以大于等于0,所以不会执行下面这句
4。&是取地址符号,(unsigned short *)表示把取到的地址强制转换成指向无符号型整数的指针,再用*运算符取出指针指向的内容。其实这句话就是把si2转换成一个临时的unsigned short 型变量
5.1L是表示长整形的1,~(1L<<)表示长整形的1左移位,再对他按位取反结果是
6。先对si2求地址指针,并把求到的地址指针转化成无符号型整数,就是说吧si2化成临时的无符号型整数,再求~(1L<<)把得到的结果和si2的无符号型整数相与(&在位运算中是与的意思),得到的结果最后在左移位。
7。这个程序并没有什么公式,如果你能把我前面的分析看懂,就会知道这个程序其实是考你对C(虽然是C++的文件,但是基本是C的内容)中基本的一些数据转换的概念。因为这个程序在实际中根本没做什么操作,你问了这么多问题说明你对C不是很熟悉,如果你要学C的话我推荐你学谭浩强的《C程序设计》很简单也很全面,网上还有电子书,最后还有对C++的介绍。
希望我打这么多字能够帮到你。
希望能解决您的问题。