C的中断和反码数据存储
2010-02-09 17:57
85 查看
标准c支持中断,但是中断函数不能传递参数,不能有返回值,严格意义上讲,中断函数不能被称作函数,因为没有执行绪主动调用它,函数调用路径是一条确定的顺序路径,由于中断处理是被动的,如果它有参数,那么谁传给它呢?如果它有返回值,它返回给谁呢?即使这样,中断处理也还是在栈上执行的,这里的栈是借用任意进程上下文的栈的,中断处理之所以在栈上是硬件体系决定的,而不是它非要在栈上不可,它完全可以切到自己的栈上去。
计算机为何用补码存储数据---以8位数据为例:
很多资料上解释了计算机使用补码存储数据的理由,比如什么可以将符号位和数据位一起参与运算等等,这些解释实际上仅仅解释了标而没有解释本,那么到底的原因是什么呢?本质的原因是由于计算机中存储数据是一种循环的环形形式而不是线性的形式,也就是说数据位总是可能满载的,比如8位的数据最大是8个1,此8个1加上1之后就会回环到0,也就是说8位的二进制位永远都不会表示大于8个1的数据,回环成了这里的决定性概念,好像时钟那样一圈一圈不停的重复,对于有符号类型,如果我们将数据的容量一分为二,那么我们就可以表示负数,如果将数据容量比作一个环形,那么从零点作为界限,右边表示正数,而左边表示负数,按照0为中点,使用二进制的加减法就可以得知为何负数是正数的二进制补码,这里补码的含义其实就是反码加1,为什么加1,正是由于有一个0在中间,归到哪里都不合适,因此归到负数的加法里面。
计算机为何用补码存储数据---以8位数据为例:
很多资料上解释了计算机使用补码存储数据的理由,比如什么可以将符号位和数据位一起参与运算等等,这些解释实际上仅仅解释了标而没有解释本,那么到底的原因是什么呢?本质的原因是由于计算机中存储数据是一种循环的环形形式而不是线性的形式,也就是说数据位总是可能满载的,比如8位的数据最大是8个1,此8个1加上1之后就会回环到0,也就是说8位的二进制位永远都不会表示大于8个1的数据,回环成了这里的决定性概念,好像时钟那样一圈一圈不停的重复,对于有符号类型,如果我们将数据的容量一分为二,那么我们就可以表示负数,如果将数据容量比作一个环形,那么从零点作为界限,右边表示正数,而左边表示负数,按照0为中点,使用二进制的加减法就可以得知为何负数是正数的二进制补码,这里补码的含义其实就是反码加1,为什么加1,正是由于有一个0在中间,归到哪里都不合适,因此归到负数的加法里面。
相关文章推荐
- C的中断和反码数据存储
- 数据在计算机中的存储形式和运算( 原码,反码,补码)&=, |=, >>=, <<=, ∧=
- java中整型数据存储方式(原码,反码,补码)
- 空间数据库引擎探究及GIS栅格和矢量数据类型的存储
- Android 数据存储之 SharedPreference
- [VS C++学习] Microsoft Visual Studio存储/读取数据的默认路径
- cocos2d-js基础 本地数据存储 碰撞检测几种方法
- IOS-数据存储之NSkeyedArchiver用法
- python 宝典 笔记 第十二章 存储数据和对象 (各种对象转换成字符串)
- SharedPreferences 数据存储功能
- IOS开发中必须熟练掌握的数据存储方式
- 数据存储之文件存储
- 数据库中存储层次树状数据
- 输入一个int型数据,计算出它在内存中存储时含1的个数
- 【数据结构】图的存储方式:邻接矩阵和邻接表
- MySQL-5.7设置InnoDB表数据文件存储位置
- sqlserver 表数据导出insert into 语句的存储过程
- 城市管网 GIS 数据表的存储
- 大数据学习笔记之二十三 云存储的统一存储和相关技术
- javascript-2存储数据