CSAPP:信息的表和处理1

关键点:寻址、内存、磁盘、虚拟地址、物理地址、整型数组。

信息存储中的几个概念整型数据类型无符号数有符号数几个概念有符号数与无符号数之间转换基于栈与基于寄存器的区别

信息存储中的几个概念

内存
  内存也被称为内存储器,其作用是用于暂时存放CPU中运算的数据,计算机中的所有程序都在内存中运行。包括只读存储器(ROM:闪存、磁盘)、随机存储器(DRAM:动态随机存储器、SRAM:静态随机存储器)和高速缓冲存储器(cache)。

  • 物理内存
      真实的硬件设备(内存条)
  • 虚拟内存
      操作系统给应用程序制造了一个假象,让每个应用程序认为自己独享4G(假设32位cpu),这个4G是一个虚拟地址空间。操作系统复负责内存管理,完成物理内存与虚拟内存之间的映射

地址
  如果把内存比作一个个小房间,那么地址就是每个房间的编号。地址总线决定寻址范围,32位CPU寻址范围位0x00000000~0xFFFFFFFF(4G)

寻址和字节顺序

  • 小端模式(little endian):低地址存放低字节,高地址存放高字节。大多数Intel都是小端模式
1int x = 0x01234567;
2char *p =(char *)&x;
3printf("%d\r\n",*p);
4*p = 0x67;
5*(p+1) = 0x45;
6*(p+2) = 0x23;
7*(p+3) = 0x01;
  • 大端模式(big endian):低地址存放高字节,高地址存放低字节。
1int x = 0x01234567;
2char *p =(char *)&x;
3printf("%d\r\n",*p);
4*p = 0x01;
5*(p+1) = 0x23;
6*(p+2) = 0x45;
7*(p+3) = 0x67;
  • 字节顺序:大小端模式可能造成的问题
  1. 网络字节序
  2. 强制类型转换或者联合(union)需要注意。

整型数据类型

无符号数

  假设一个整数数据类型有w位。则其数据范围位为0~。32位平台下long = int ,64位平台下long站8位。

32位平台

数据类型 位数 最小值 最大值
unsigned char 8 0 255
unsigned short 16 0 65535
unsigned int 32 0 4294967295
unsigned long 32 0 4294967295
uint32_t 32 0 4294967295
uint64_t 64 0 18446744073709551615

64位平台

数据类型 位数 最小值 最大值
unsigned char 8 0 255
unsigned short 16 0 65535
unsigned int 32 0 4294967295
unsigned long 64 0 18446744073709551615
uint32_t 32 0 4294967295
uint64_t 64 0 18446744073709551615

有符号数

  假设一个整数数据类型有w位。则其数据范围位为~.有符号数+无符号数 =

32位平台

数据类型 位数 最小值 最大值
char 8 -128 127
short 16 -32768 32767
int 32 -2147483648 2147483647
long 32 -2147483648 2147483647
int32_t 32 -2147483648 -2147483647
int64_t 64 -9223372036854775808 9223372036854775808

64位平台

数据类型 位数 最小值 最大值
char 8 -128 127
short 16 -32768 32767
int 32 -2147483648 2147483647
long 64 -9223372036854775808 9223372036854775808
int32_t 32 -2147483648 2147483647
int64_t 64 -9223372036854775808 9223372036854775808

几个概念

  数值在计算机中都是以补码形式存在的。

  • 原码:符号位加上真值的绝对值。即第一位表示符号位,其余位表示值
  • 反码:正数反码等于其原码(本身),负数反码在其原码基础上,符号位不变,其余各位取反。
  • 补码:整数补码等于本身,负数 = 反码 + 1。
数值 原码 反码 补码
85 01010101 01010101 01010101
-85 11010101 10101010 10101011

有符号数与无符号数之间转换

  实际上是无符号数与补码之间的转换。-85 = 10101011 = 171U。一个w位的有符号数,假设其值位X(负数),其对应的无符号值为Y,则有:

基于栈与基于寄存器的区别

  • 可移植性:基于寄存器的CPU架构,依赖于平台,寄存器指令不同。
  • 不用考虑寄存器分配问题:基于栈的架构,不用考虑寄存器

CSAPP:信息的表和处理1的更多相关文章

  1. CSAPP:信息的表和处理2

    CSAPP:信息的表和处理2 关键点:浮点数.浮点数运算. 二进制小数IEEE浮点数表示浮点数转换(单精度)参考 二进制小数   形如表示的二进制数,其中每个位的取值范围位0和1.这种表示方式的定义如 ...

  2. 【原创】C#搭建足球赛事资料库与预测平台(4) 比赛信息数据表设计

            本博客所有文章分类的总目录:[总目录]本博客博文总目录-实时更新 开源C#彩票数据资料库系列文章总目录:[目录]C#搭建足球赛事资料库与预测平台与彩票数据分析目录 本篇文章开始将逐步介 ...

  3. usb由于其配置信息(注册表中的)不完整或已损坏,Windows 无法启动这个硬件设备

    在设备管理器的usb设备的属性中,显示提示“由于其配置信息(注册表中的)不完整或已损坏,Windows 无法启动这个硬件设备”.注册表坏了.经过查询,解决方法如下: 方法:打开注册表编辑器(开始--& ...

  4. SQL查询数据库信息, 数据库表名, 数据库表信息

    SQL查询数据库信息, 数据库表名, 数据库表信息 ---------------------------------------------- -- 以下例子, 在sql_server 中可以直接运 ...

  5. [z]dbms_stats.lock_table_stats对于没有统计信息的表分区同样有效

    常见的分区表DDL如 split partition.add partition都会生成没有统计信息的表分区table partition,长期以来我对dbms_stats.lock_table_st ...

  6. 查看mysql 库信息和表结构与表创建方法

    一.查看基础信息 1.查看数据库存储位置 show global variables like "%datadir%"; 2.查看数据库的版本 select version(); ...

  7. destoon 信息发布表单提交验证

    sell 模块的form表单如下: <form method="post" id="dform" action="?" target= ...

  8. Dynamics 365客户端编程示例:获取当前用户的信息,表单级通知/提示,表单OnLoad事件执行代码

    我是微软Dynamics 365 & Power Platform方面的工程师罗勇,也是2015年7月到2018年6月连续三年Dynamics CRM/Business Solutions方面 ...

  9. SQL 从指定表筛选指定行信息 获取表行数

    1.获取指定表的行数 --获取表中数据行数 --select max([列名]) from 表名 2.筛选指定表的指定行数据(数据表分页获取) http://www.cnblogs.com/morni ...

随机推荐

  1. python文件

    目录 1. 文件的概念 1.1 文件的概念和作用 1.2 文件的存储方式 2. 文件的基本操作 2.1 操作文件的套路 2.2 操作文件的函数/方法 2.3 read 方法 -- 读取文件 2.4 打 ...

  2. 【Spring】27、JPA 实现乐观锁@Version注解的使用

    持久层使用jpa时,默认提供了一个注解@Version来实现乐观锁 简单来说就是用一个version字段来充当乐观锁的作用.先来设计实体类 /** * Created by xujingfeng on ...

  3. MySQL技巧(二)——无限级分类表设计

    无限级分类表的设计(掌握'自身连接') 类似图书这种,会有很多种分类,而且在现实生活中这种分类会无限的往下分,所以不可能每有一个分类就创建一个分类表.应该使用下面这种语句 DROP TABLE IF ...

  4. 史上最全python面试题详解(三)(附带详细答案(关注、持续更新))

    38.面向对象深度优先和广度优先是什么? 39.面向对象中super的作用? 40.是否使用过functools中的函数?其作用是什么? Python自带的 functools 模块提供了一些常用的高 ...

  5. PHP实现二分法查找

    二分查找法需要数组是一个有序的数组. <?php function binarySearch($num, $arr) { $start = 0; $end = count($arr); $mid ...

  6. Flask 系列之 Pagination

    说明 操作系统:Windows 10 Python 版本:3.7x 虚拟环境管理器:virtualenv 代码编辑器:VS Code 实验目标 实现当前登录用户的事务浏览.添加.删除 操作 实现 首先 ...

  7. jQuery根据元素值或元素下标来删除一个数组元素及数组对象方法列表

    在前提不知道b在这个数组的下标,删除b这个元素  var arrList = ['a','b','c','d'];         arrList.splice(jQuery.inArray('b', ...

  8. vuejs2.0实现一个简单的分页

    用js实现的分页结果如图所示: css .page-bar{ margin:40px; } ul,li{ margin: 0px; padding: 0px; } li{ list-style: no ...

  9. BZOJ 1874: [BeiJing2009 WinterCamp]取石子游戏(SG函数)

    Time Limit: 5 Sec  Memory Limit: 162 MBSubmit: 871  Solved: 365[Submit][Status][Discuss] Description ...

  10. 简析服务端通过geotools导入SHP至PG的方法

    文章版权由作者李晓晖和博客园共有,若转载请于明显处标明出处:http://www.cnblogs.com/naaoveGIS/ 1.背景 项目中需要在浏览器端直接上传SHP后服务端进行数据的自动入PG ...