|
转自CN-DOS论坛,顺便把一些乱七八糟的带上来了
-------------------------------------------
批处理set命令中的算数运算符和逻辑运算符,新手请看
Dos下的写法 批处理中的写法 符号的含义和取值范围
按位异或:num1^^num2 num1^^num2 转2进制补码,按位判断,相异为1,相同为0,转10进制输出,
按位与: num1^&num2 num1^&num2 转2进制补码,按位判断,全1为1,否则为0,转10进制输出
按位或: num1^|num2 num1^|num2 转2进制补码,按位判断,全0为0,否则为1,转10进制输出
加: num1+num2 num1+num2
减: num1-num2 num1-num2
乘: num1*num2 num1*num2
除: num1/num2 num1/num2 结果向零取整,num2不为0
求余: num1%num2 num1%%num2 num2不为0,num2为负数当同绝对值的正数处理,num2为负数时当正数计算,然后结果取负
按位取反:~num ~num 转2进制,1变成0,0变成1,以补码的十进制形式输出
逻辑非: !num !num num为0输出1,不为0输出0
求负: -num -num
逻辑左移:num1^<^<num2 num1^<^<num2 转2进制补码,num1所有位向左移num2个位数,移几位后面填几个0,转十进制输出,num2为负时输出0
逻辑右移:num1^>^>num2 num1^>^>num2 转2进制补码,num1所有为向右移num2个位数,转十进制输出,num2为负时输出0
-------------------------------------------------
什么叫进制
当我们用数字表示数量时,存在一个问题:
我们要表示的事物的量可能很大,数字的数量是有限的,如何用有限的数字表示
很多的数量?
有效的办法就是把数字连起来,利用数字位置的不同来表示他所代表的数量
,如123中的1代表100,2代表20,1代表1
初步理解,进制就是我们表是一个完整的正整数集需要的字符的数量
十进制:我们用的最多,他用了123456790十个数字
二进制:用了1 和0两个数字,计算机使用二进制是依赖于电路的基本结构,可以说是“被迫”使用(有关资料说,3进制是“最优秀的”,可惜在大型集成电路上很难实现)要了解计算机,第一步就是了解2进制
下面列举几个2进制数
111010001
110001100
看到了吧?只有1和0(别问我为什么2进制没有2?,我晕!)
加发运算和十进制类似,上过小学的都会,无非是满2进1!
算乘法就是算加法,3乘5,计算机就计算3+3+3+3+3,计算机是不是很笨?只认识0和1,算减法也要当加法算,减法怎么算的我以后在说
------------------------------------------------------
可能会先算 3*2^2+3
11---乘以2^2--->1100
1100+11=1111 (15)
-------------------------------------------------------
可能会先算 3*2^2+3
11---乘以2^2--->1100
1100+11=1111 (15)
------------------------------------------------------
什么叫补码
负数的表示法
负数要表示成2进制怎么半呢?你会说,那就在前面加个负号。问题是计算机只认
识1和0啊,负号怎么表示呢?于是有人提出在2进制数字的前面加上1代表负数
加上0代表正数。这样表示很直观,但是有个问题,0怎么表示?存在两个零,正
的零等于负的零,就因为这两个零给数据运算带来了很大的麻烦,我们才引进了
“补码”的概念。“补码”里只有一个零,每个单一数值和唯一编码相对应,才
符合计算机运算的要求。
正数的补码和原码一致,0的补码是0000000,负数的补码是他相反数逐位取反再
加一
比如1的源码表示为00000001,逐位取反后变成了11111110,(称为反码),在加
1 就变成了11111111,这个11111111就表示负1
还有一种方法理解11111111表示-1:0不是表示为0000000吗,那0减去1 就表示-1
了,什么?不够减?向想象中的第九位借位(暂时不要考虑高位的问题),结果
出来了11111111,那负2呢?-1在减1被,你看:
11111111在减1等于11111110,其他的负数聪明的读者,你会表示了吗?
在这里要注意一个特殊的数:-128,表示成10000000
-129呢?很抱歉在八个位数的二进制中无法表式,需要用十六位二进制数表式如
下1111111101111111这个数再加1就是1111111110000000也就是-128
有人要问了,10000000和1111111110000000不同啊,怎么表是同样的数?
那我们用正数的时候00000001和1都表示1,1前面的全零串没有意义
负数正好相反,零前面的全1串没有意义,相加多少都行
我举例子的时候用的都是8位的和16位的,8位组成一个字节,表式一个数最少用8
位,数字再大就用16位,再就是18位的。反正是8的倍数。
在数字前面加上若干零或者1的过程,我们叫它“扩展到高位字节”
上个帖子提到了怎么算减法,就是把减正看成加负,负数一律表示成补码
,补码不分正负,只要相加就行了,简单吧?
这一讲最后说说取值范围:一个8位能表示2的8次方个数,就是256
一个16位能表示65536个数
我们不需要表示负数的时候使用“无符号数”8位的取值范围是0~255,16位的取
值范围是0~65535.无符号数就是不用补码的数
我们需要表示负数的时候要用“有符号数”8位的取值范围是-128~127,16位的取
值范围是-32768~32767
下一讲要讲逻辑运算符和算术运算符
----------------------------------------------------------
^运算符
转2进制补码,按位判断,相异为1,相同为0,转10进制输出
10 ^ 8 = 2
00001010 ^ 00001000 = 00000010
&运算符
转2进制补码,按位判断,全1为1,否则为0,转10进制输出
10 & 8 = 8
00001010 & 00001000 = 00001000
|运算符
转2进制补码,按位判断,全0为0,否则为1,转10进制输出
10 | 8 = 10
00001010 | 00001000 = 00001010
>>运算符
转2进制补码,num1所有位向左移num2个位数,移几位后面填几个0,转十进制输出,num2为负时输出0
10 >>1 = 5
00001010 >>1 = 00000101
<<运算符
转2进制补码,num1所有为向右移num2个位数,转十进制输出,num2为负时输出0
10 <<1 = 20
00001010 >>1 = 000010100
----------------------------------------------
13的二进制下面讲讲负数的补码怎么转化成数值,以11110010为例,首先按位取反变成00001101,在加一,变成00001110,转化成二进制的14,在加-,变成-14
负数的补码转换成数值的规律是取反加1,再加负号
是1101,前面补上0000,变成00001101,在按位取反,变成11110010,这是个补码,转换成十进制,变成-14
-------------------------------------------------- |
|