[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中有两个智能指针类型, ...
随机推荐
- socketserver模块使用 & websocket
socketserver: socketserver可用于实现并发通信. socketserver 模块简化了编写网络服务程序的任务:同时 SocketServer 模块也是 Python标准库中很多 ...
- CSU - 1333 1333: Funny Car Racing(spfa)
http://acm.csu.edu.cn/OnlineJudge/problem.php?id=1333 这题多了一个限制条件是每一条路都会规律的开放a时间关闭b时间,车子必须在开放的时候进入,在关 ...
- [bzoj2058][Usaco2010 Nov]Cow Photographs_树状数组_动态规划
Cow Photographs bzoj-2058 Usaco-2010 Nov 题目大意:给定一个n的排列.每次操作可以交换相邻两个数.问将序列变成一个:$i,i+1,i+2,...,n,1,2,. ...
- 洛谷 P2064 奇妙的汽车
P2064 奇妙的汽车 题目描述 你有着一辆奇妙的汽车,这辆汽车有着自动加速的功能.打个比方吧,第1天你驾驶着它可以行驶a路程,那么第2天你可以让它所走的路程增加到第1天的2~9倍(必须是其中一个整数 ...
- eclipse断点有个斜杠 skip all breakpoints
切换到debug,单击下 skip all breakpoints 即可
- Python进阶系列之怎么写出pythonic的代码
使用 in/not in 检查key是否存在于字典中 判断某个key是否存在于字典中时,一般的初学者想到的方法是,先以列表的形式把字典所有的key返回,在判断该key是否存在于key列表中 d = { ...
- SDUTOJ 2476Period
#include<iostream> #include<string.h> #include<stdio.h> #define N 1000010 using na ...
- HTTP请求库——axios源码阅读与分析
概述 在前端开发过程中,我们经常会遇到需要发送异步请求的情况.而使用一个功能齐全,接口完善的HTTP请求库,能够在很大程度上减少我们的开发成本,提高我们的开发效率. axios是一个在近些年来非常火的 ...
- c#基于事件模型的UDP通讯框架(适用于网络包编解码)
之前写过一篇关于c#udp分包发送的文章 这篇文章里面介绍的方法是一种实现,可是存在一个缺点就是一个对象序列化后会增大非常多.不利于在网络中的传输. 我们在网络中的传输是须要尽可能的减小传送的数据包的 ...
- OpenCV 2.4.8 or OpenCV 2.4.9组件结构全解
近期发现了一个好的opencv博客,准备依照他的顺序系统学习opencv,而且会一一转载过来 之前啃了不少OpenCV的官方文档,发现假设了解了一些OpenCV总体的模块架构后.再重点学习自己感兴趣的 ...