《计算机科学基础》学习笔记_Part 1 Computer and Data
Chapter 1. Introduction
Ø 计算机:黑盒,Output Data=f(Input Data, Program)
Ø Von Neumann模型:内存(Memory)、算术逻辑单元(Arithmetic Logic Unit)、控制单元(Control Unit)、输入/输出(Input/Output)
CPU=Arithmetic Logic Unit + Control Unit
Ø 程序(Program):A sequence of instructions
算法(Algorithm):Step-by-step solution to solve problem
Ø 三个时期:Mechanical Machines、Electronic Computers、Computer Generations(Vacuum Tube、Transistor、Integrated Circuit、Micro-computer、Laptop and Palmtop)
Ø 第一台计算机:EDVAC,Electronic Discrete Variable Automatic Computer
Chapter 2 Data Representation
Ø 数据类型:文本text,数字number,图像image,音频audio,视频video。->多媒体multimedia
Ø 数据存储形式:
u 位bit是计算机可以存储的最小单位(0或1)
u 位模式bit pattern:一串“位”a string of bits
u 内存以位模式的形式存储数据,输入/输出设备的作用是解释位模式的数据类型
Ø 文本数据
u 由语言中字符数的多少来决定位模式的长度,两者呈对数关系:
u ASCII:
l American Standard Code for Information Interchange
l 7 bits,128 symbols,0000000-1111111
l First pattern(0000000)代表“空null”
l Last pattern(1111111)代表“删除delete”
l 31个控制符control characters,不可打印
l 数字(0-9)在字母前
l 多个可打印字符
l 大写字母Uppercase letters(A-Z)出现在小写字母Lowercase letters(a-z)前
l 大小写字母只想差一位:右侧数第六位,小写字母为1,大写字母为0
l 大小写字母间有六个特殊字符
u Extended ASCII
l 在ASCII前增加一位0
l 不同厂商之间未能统一
u EBCDIC
l Extended Binary Coded Decimal Interchange Code
l IBM使用
u Unicode
l 16 bits,65536 symbols
l 英语之外的符号
l 不同节表示不同的语言
u ISO
l International Organization for Standardization
l 32 bits, 4294967296 symbols
Ø 数字
u 二进制Binary system
u 类似于ASCII编码并不用于表示数字
Ø 图像
u 位图Bitmap Graphic
l 像素pixel, picture elements;分辨率resolution
l 每像素安排一个bit pattern。若为黑白,则1 bit;若为四阶灰,2 bits;若彩色,RGB(Red, Green, Blue),8 bits each,24位真色彩True color
u 矢量图Vector Graphic
l 由曲线Curves和直线Lines组成
l 由数学公式mathematical formula表示
l 不失真
Ø 音频
u 模拟数据analog data->数字数据digital data
u 音频源Audio->抽样Sampling->量化Quantization->编码Coding->二进制位模式Binary Pattern
Ø 视频
u 连续的图像:帧frames
Ø 十六进制表示法Hexadecimal Notation
u 16 symbols:0123456789ABCDEF
u 位模式表示为十六进制查看更清晰
u 4-bit pattern可由一个十六进制的字符表示,反之亦然
u 表示:数据前加小写x或在数据后用下标16标注
Ø 八进制表示法Octal Notation
u 8 symbols:01234567
u 3-bit pattern可由一个八进制字符表示,反之亦然
u 表示:数字前加数字0(有时也用小写字母o)或在数字后用下标8标注
Chapter 3 Number Representation
Ø 十进制与二进制
u 二进制->十进制:按位乘权重后相加
u 十进制->二进制:整数部分循环除以2后余数由低位向高位排列直至商为0,小数部分循环乘以2取整直至积为0
Ø 整数的表示
u 整数:正数、负数;无符号,带符号(原码,反码,补码)
u 溢出overflow:超出最大的存储范围
u 无符号整型Unsigned Integer Format:
l 范围:
l 表示:转换为二进制,左侧补零
l 翻译:转换为十进制
l 应用:计数Counting;寻址Addressing
u 原码(符号+绝对值)Sign-and-Magnitude
l 范围:
l 表示:忽略符号转换为二进制,补零至N-1位,第一位根据符号补全(1->负号,0->正号)
l 翻译:忽略符号位转换为十进制,添加符号
l 应用:数模转换
l 特点:第一位存储符号;存在两个0(+0;-0)
u 反码One’s Complement
l 范围:
l 表示:忽略符号转换为二进制,左侧补零,正数不变,负数取反
l 翻译:0开头->转换为十进制;1开头->取反,转换为十进制,加负号
l 应用:数据交互
l 特点:第一位存储符号;正数原码,负数反码;存在两个0(+0;-0);正数取反得相应负数,负数取反得相应正数,两次取反得到原数
u 补码Two’s Complement
l 范围:
l 表示:忽略符号转换为二进制,左侧补零,根据符号取反(正数不变,负数右起第一个1左侧各位取反)
l 翻译:0开头->二进制转换为十进制,添加正号;1开头->右起第一个1左侧各位取反,转换为十进制,添加符号
l 应用:目前计算机存储
l 特点:只包含一个0;起点比相同位反码小1;正数的补码是相应的负数,负数的补码是相应的正数,两次补码得到原数
Ø 超码Excess System
l 表示:整数与幻数magic number(一般为或,在Excess_后给出,如Excess_127)相加,转换为二进制,左侧补零
l 翻译:转换为十进制,减去幻数
l 应用:用于存储指数部分
Ø 浮点型Floating-Point:整数integer+小数Fraction
u 构成:符号Sign+指数Exponent+尾数mantissa
l 符号:一位,0或1
l 指数:底数为2,包含符号,使用超码表示
l 尾数:小数点后部分,使用无符号整型表示
u 归一化Normalization:对于二进制,移动小数点使小数点左侧只保留一个1。移动小数点e位,向左移动乘,向右移动乘。
u 表示:(以单精度为例)存储符号(”0”->”+”,”1”->”-“),以超码的形式(Excess_127)存储指数部分(2为底数),以无符号整型存储尾数部分(1与小数点省略。)
u 解释:(以单精度为例)最左位为符号;接下来8位加上127,作为指数部分;为接下来的23位添加“1”和小数点,可忽略最右侧的“0”;移动小数点到正确位置;转换为十进制。
Chapter 4 Operations on Bits
Ø Arithmetic Operations
u 乘,叠加Multiplication,repeated addition;除,叠减Division,repeated subtraction
u 补码加法:按位加减,逢2进1(carry),最左侧进位舍弃
u 补码减法:加上另一个数的补码
u 溢出overflow:an error that occurs when you try to shore a number that is not within the range defined by the allocation.
u 浮点数运算
l 检查符号:
n 相同:直接加减并指定符号
n 不同:比较绝对值,大数减小数,使用大数符号
l 移动小数点使指数相同(指数小的尾数小数点左移)
l 尾数加减(整数、小数)
l 结果归一化
l 检查溢出
Ø Logical Operations
u 一元操作Unary operator & 二元操作
u 真值表True Tables
l 非门Not Operator:NOT(0)->1;NOT(1)->0
l 与门AND Operator:(0)AND(X)->0;(X)AND(0)->0
l 或门Or Operator:(1)OR(X)->1;(X)OR(1)->1
l 异或门XOR Operator:(1)XOR(X)->NOT(X);(X)XOR(1)->NOT(X)
u 掩码Mask
l AND:复位(0复位,1不变)
l OR:置位(1置位,0不变)
l XOR:反转(1反转,0不变)
u 移位Shift Operations
l 只适用无符号整型
l 右移:弃最右位,左补0,除进制
l 左移:弃最左位,右补0,乘进制
《计算机科学基础》学习笔记_Part 1 Computer and Data的更多相关文章
- 【C#编程基础学习笔记】4---Convert类型转换
2013/7/24 技术qq交流群:JavaDream:251572072 教程下载,在线交流:创梦IT社区:www.credream.com [C#编程基础学习笔记]4---Convert类型转换 ...
- 【C#编程基础学习笔记】6---变量的命名
2013/7/24 技术qq交流群:JavaDream:251572072 教程下载,在线交流:创梦IT社区:www.credream.com [C#编程基础学习笔记]6---变量的命名 ----- ...
- 1.C#基础学习笔记3---C#字符串(转义符和内存存储无关)
技术qq交流群:JavaDream:251572072 教程下载,在线交流:创梦IT社区:www.credream.com ------------------------------------- ...
- Java基础学习笔记总结
Java基础学习笔记一 Java介绍 Java基础学习笔记二 Java基础语法之变量.数据类型 Java基础学习笔记三 Java基础语法之流程控制语句.循环 Java基础学习笔记四 Java基础语法之 ...
- Learning ROS for Robotics Programming Second Edition学习笔记(五) indigo computer vision
中文译著已经出版,详情请参考:http://blog.csdn.net/ZhangRelay/article/category/6506865 Learning ROS for Robotics Pr ...
- Mysql数据库基础学习笔记
Mysql数据库基础学习笔记 1.mysql查看当前登录的账户名以及数据库 一.单表查询 1.创建数据库yuzly,创建表fruits 创建表 ) ) ,) NOT NULL,PRIMARY KEY( ...
- 0003.5-20180422-自动化第四章-python基础学习笔记--脚本
0003.5-20180422-自动化第四章-python基础学习笔记--脚本 1-shopping """ v = [ {"name": " ...
- Java基础学习笔记(一)
Java基础学习笔记(一) Hello World 基础代码学习 代码编写基础结构 class :类,一个类即一个java代码,形成一个class文件,写于每个代码的前端(注意无大写字母) XxxYy ...
- C#RabbitMQ基础学习笔记
RabbitMQ基础学习笔记(C#代码示例) 一.定义: MQ是MessageQueue,消息队列的简称(是流行的开源消息队列系统,利用erlang语言开发).MQ是一种应用程序对应用程序的通信方法. ...
随机推荐
- hdu 1026(BFS+输出路径) 我要和怪兽决斗
http://acm.hdu.edu.cn/showproblem.php?pid=1026 模拟一个人走迷宫,起点在(0,0)位置,遇到怪兽要和他决斗,决斗时间为那个格子的数字,就是走一个格子花费时 ...
- HTTP.ResponseCode
HTTP响应码: http://blog.csdn.net/cutbug/article/details/4024818
- Writing modular applications with laravel-modules
01-07-2016 Let me start by saying Laravel is an amazing framework. However when it comes to writing ...
- python 字典遍历
dic1={"name":"kxb","age":28}for k,v in dic1.items(): print(k+",,, ...
- 【jquery+easyUI】-- $.messager.show 弹框显示
三种基本弹框 1.提示框,一秒停留 $.messager.show({ title: '提示', msg: '修改成功!', showType: 'fade', //设置显示类型 style: { l ...
- 基于centos6.5 hbase 集群搭建
注意本章内容是在上一篇文章“基于centos6.5 hadoop 集群搭建”基础上创建的 1.上传hbase安装包 hbase-0.96.2-hadoop2 我的目录存放在/usr/hadoop/hb ...
- 浅谈Spring中的Quartz配置
浅谈Spring中的Quartz配置 2009-06-26 14:04 樊凯 博客园 字号:T | T Quartz是一个强大的企业级任务调度框架,Spring中继承并简化了Quartz,下面就看看在 ...
- Apache Prefork、Worker和Event三种MPM分析
三种MPM介绍 Apache 2.X 支持插入式并行处理模块,称为多路处理模块(MPM).在编译apache时必须选择也只能选择一个MPM,对类UNIX系统,有几个不同的MPM可供选择,它们会影响到 ...
- 再读c++primer plus 003
1.如果函数返回一个结构而不是一个指向结构的引用,将把整个结构复制到一个临时位置,再将这个拷贝复制给dup.但在返回值为引用时,将直接复制给变量,其效率更高. 2.返回引用时最重要的一点是,应避免返回 ...
- 使用delphi 10.2 开发linux 上的Daemon
delphi 10.2 支持linux, 而且官方只是支持命令行编程,目地就是做linux 服务器端的开发. 既然是做linux服务器端的开发,那么普通的命令行运行程序,然后等待开一个黑窗口的方式就 ...