[C和指针] 6-指针
6.1 内存和地址
我们可以把计算机的内存看作是一条长街上的一排房屋,每座房子都可以容纳数据,并通过一个房号来标识。
这个比喻颇为有用,但也存在局限性。计算机的内存由以亿万计的位(bit)组成,每个位都可以容纳值0或1.由于一个位所能表示的值的范围太有限,所以单独的位用处不大,
通常许多位合成一组作为一个单位,这样就可以存储范围较大的值。这里有一幅图,展示了现实机器中的一些内存位置。

这些位置的每一个都被称为字节(byte),每个字节都包含了存储一个字符所需要的位数。上面这张图并没有显示这些位置的内容,但内存中的每个位置总是包含一些值。
每个字节通过地址标识,如上图方框上面的数字所示。
为了存储更大的值,我们把两个或更多个字节合在一起作为一个更大的内存单位。例如,许多机器以字为单位存储整数,每个字一般由2个或4个字节组成。下面这张图所表示的内存位置与上图相同,但这次它以4个字节的字表示。

注意,尽管一个字包含了4个字节,它仍然只有一个地址。在要求边界对齐的机器上,整型值存储的起始位置只能是某些特定的字节,通常是2或4的倍数。注意:
- 内存中的每个位置都有一个独一无二的地址;
- 内存中的每一个位置都包含一个值。
地址与内容
这里有另外一个例子,这次它显示了内存中5个字的内容

这里显示了5分整数,每个都位于自己的字中。如果你记住了一个值的存储地址,可以通过这个地址取得这个值。但是,要记住所有这些地址实在是太笨拙了,所以高级语言所提供的特效之一
就是通过名字而不是地址来访问内存的位置。下面这张图与上图相同,但这次使用名字来代替地址。

当然,这些名字就是我们所称的变量,名字与内存关联并不是硬件提供的,它是由编译器为我们实现的。所有这些变量给了我们一种更方便的方法记住地址----硬件仍然通过地址来访问内存位置。
6.2 值和类型[注意]
现在让我们来看一下存储于这些位置的值,头两个位置所存储的是整数。第3个位置所存储的是一个非常大的整数。第4、5个位置存储的也是整数。下面是这些变量的声明:
int a = 112, b = -1;
float c = 3.14;
int d = &a;
float e = &c;
在这些位置中,变量a和b确实用来存储整型值。但是,它声明c所存储的是浮点值。可是,在上图中c的值却是一个整数。那么它到底是哪个呢?整数还是浮点数?
答案是该变量包含了一序列为0或者1的位。它们可以被解释为整数,也可以被解释为浮点数,这取决于它们被使用的方式。如果使用的是整型算术指令,这个值被解释为整数。如果使用的是浮点型指令,就被解释为浮点数。
这个事实引出了一个重要的结论:`不能简单地通过检查一个值的位来判断它的类型`。为了判断值的类型(以及它的值),你必须观察这个值的使用方式。考虑下面这个以二进制形式表示的32位值:
011001110110110001101111101100010
下面是这些位可能被解释的许多结果中的几种。

这里,一个单一的值可以被解释为5种不同的类型。显然,值的类型并非值本事所固有的一种特性,而是取决于它的使用方式。
当然,编译器会帮助我们避免这些错误,如果我们把c声明为float类型,那么当程序访问它时,编译器就会产生浮点型指令。如果我们以某种对float类型而言不合适的方式访问该变量时,编译器就会发出错误或警告消息。
6.3 指针变量的内容
让我们把话题返回到指针,看看变量d和c的声明,它们都被声明为指针。

d和e的内容是地址而不是整型或浮点型数值。事实上,d的内容与a的存储地址一致,而e的内容与c的存储地址一致。区分变量d的地址(112)和它的内容(100)是非常重要的,同时也必须意识到100这个数值用于标记其他位置(变量a的地址)。
6.4 间接访问操作符
[C和指针] 6-指针的更多相关文章
- C与指针(结构体指针,函数指针,数组指针,指针数组)定义与使用
类型 普通指针 指针数组(非指针类型) 数组指针 结构体指针 函数指针 二重指针 定义方式 int *p; int *p[5]; int (*p)[5]; int a[3][5]; struct{.. ...
- C/C++:提升_指针的指针和指针的引用
C/C++:提升_指针的指针和指针的引用 写在前面 今天在使用指针的时候我发现了一个自己的错误.
- 理清C++常量指针和指针常量这团乱麻
写在前面: 与其说C++中的常量指针和指针常量是一块很有嚼头的语法糖,不如说它是一块相当难啃的骨头.其实本来没什么,这无非是const int *p与int* const p的区别, 但一涉及到起名字 ...
- 详解c++指针的指针和指针的引用
展示一下使用指针的指针和指针的引用修改传递给方法的指针,以便更好的使用它.(这里说的指针的指针不是一个二维数组) 为什么需要使用它们 当我们把一个指针做为参数传一个方法时,其实是把指针的复本传递给了方 ...
- 指针的指针&指向指针数组的指针
一.指针的指针 指针的指针看上去有些令人费解.它们的声明有两个星号.例如: char ** cp; 如果有三个星号,那就是指针的指针的指针,四个星号就是指针的指针的指针的指针 ...
- C语言 详解多级指针与指针类型的关系
//V推论①:指针变量的步长只与‘指针变量的值’的类型有关(指针的值的类型 == 指针指向数据的类型) //指针类型跟指针的值有关,指针是占据4个字节大小的内存空间,但是指针的类型却是各不相同的 // ...
- C/C++ 一段代码区分数组指针|指针数组|函数指针|函数指针数组
#include<stdio.h> #include<stdlib.h> #include<windows.h> /* 举列子说明什么是函数指针 */ //以一个加 ...
- C++ 必知必会:条款15 成员的指针并非指针
指向类成员的类成员的指针说是“指针”,其实是不合适的,因为他既不包含地址,其行为也不像指针 常规的指正,包含地址,对其解应用可以得到该指针包含地址所指向的对象 1: int a = 12: 2: in ...
- o4.数组指针和指针数组的区别
------- android培训.iOS培训.期待与您交流! ---------- 我们看一下数组指针和指针数组: 数组指针(也称行指针)定义 int (*p)[n];()优先级高,首先说明p是一个 ...
- 不可不表的OSG智能指针之强指针与弱指针 《转载》
不可不表的OSG智能指针之强指针与弱指针 <转载> 使用OSG的人都知道OSG的内存管理方式采用了智能指针,通过智能指针的方式让OSG自己处理对象的销毁工作.在OSG中有两个智能指针类型, ...
随机推荐
- linux 磁盘阵列
1.独立磁盘冗余阵列 (RAID) 2.RAID级别: raid0 扩展卷 (条带卷) 至少一块硬盘 具有较高的存储性能 数据请求多块硬盘并行应答 连续数据分散到多个磁盘存储 ,一块磁盘坏掉所有文件就 ...
- csu - 1566: The Maze Makers (bfs)
http://acm.csu.edu.cn/OnlineJudge/problem.php?id=1566 题意还是蛮难懂的,至少对于我来说,需要认真读题. 输入矩阵的每一个数字换成2进制后,顺时针围 ...
- POJ 3686_The Windy's
题意: N个工件要在M个工厂加工,一个工件必须在一个工厂做完,工厂一次只能处理一个工件.给定每个工件在每个工厂加工所需时间,求出每个工件加工结束的最小时间平均值. 分析: 工厂一次只能处理一个工件,那 ...
- DTRACE简介(2)
By samwan on 三月 21, 2007 通过上一次的介绍,相信大家对DTRACE已经有了一个初步的认识.上一次结束时专门留了一个例子,可能大家第一次看有很多不明白的地方,没有关系,随着我们对 ...
- symfony 使用原始sql
$this->get('database_connection')->fetchAll('select * from book where book.id=3')
- POJ3977 Subset 折半枚举
题目大意是给定N个数的集合,从这个集合中找到一个非空子集,使得该子集元素和的绝对值最小.假设有多个答案,输出元素个数最少的那个. N最多为35,假设直接枚举显然是不行的. 可是假设我们将这些数分成两半 ...
- A. Polo the Penguin and Strings
time limit per test 2 seconds memory limit per test 256 megabytes input standard input output standa ...
- 蓝桥杯 地宫寻宝 带缓存的DFS
历届试题 地宫取宝 时间限制:1.0s 内存限制:256.0MB 问题描写叙述 X 国王有一个地宫宝库. 是 n x m 个格子的矩阵. 每一个格子放一件宝贝. 每一个宝贝贴着价 ...
- sharepoint 訪问缩略图
Sharepoint缩略图 简单介绍 Sharepoint2010中有专门的图片库,当你新建图片库后,向图片上传一部分图片.当你浏览这个库时显示一排排小图片.当点击一个图片时进入显示的是大图.不要简单 ...
- java UDP聊天与文件传输
package rgy.com.UDP3; import java.awt.Font; import java.awt.GridLayout; import java.awt.event.Action ...