《C语言程序设计进阶教程》一2.1 值和地址

简介: 本文讲的是《C语言程序设计进阶教程》一2.1 值和地址,本节书摘来华章计算机《C语言程序设计进阶教程》一书中的第2章,第2.1节, Intermediate C Programming[美] 陆永祥(Yung-Hsiang Lu) 著 徐东 译 译更多章节内容可以访问云栖社区“华章计算机”公众号查看。

第2章

栈 内 存

2.1 值和地址

本文讲的是C语言程序设计进阶教程一2.1 值和地址,在计算机中,程序和数据必须保存在叫作存储器(storage)的地方。没有存储器,计算机就没有可以计算的东西。存储器可以分为易失的和非易失的。易失的存储器需要供电,它只有在计算机开机的时候才能保存数据。易失的存储器通常叫作“内存”。非易失存储器可以在计算机关机或者重启的时候保存数据,例如,闪存或者硬盘。闪存也叫作固态硬盘或SSD。
现在一个典型的笔记本电脑会有几个GB的内存。G代表着“giga”(千兆),是公制度量系统中十亿的前缀。B代表着“byte”(字节),是一个8位的序列。每一位可以存储0或1。如果一台笔记本电脑拥有8GB的内存,它就可以在内存中存储640亿位的信息。作为参照,全世界的人口在2013年大概是70亿。
计算机的内存被编组成地址–值这样的关系对。这些对的作用类似于街道地址和住在那里的家庭之间的关系。考虑下面的情形:
screenshotJones一家住在One Silicon街道。
screenshotSmith一家住在Two Silicon街道。
screenshotBrown一家住在Three Silicon街道。
screenshotTaylor一家住在Four Silicon街道。
screenshotClark一家住在Five Silicon街道。
我们可以在一张表中表达这个信息:
screenshot
在计算机的内存中,每个位置储存的不是0就是1——就像下面一样:
screenshot0存储在第1个位置。
screenshot0存储在第2个位置。
screenshot1存储在第3个位置。
screenshot0存储在第4个位置。
screenshot1存储在第5个位置。
我们也可以用一张表来表达:
screenshot
程序员通常一次考虑不止一位。我们暂且可以把数据的大小放在一边。相反,假定每一块数据占据着内存的一个单元。操作系统保证任何内容都有一个唯一的正数地址。地址不为零或负数。标志符NULL被定义为零地址,表明是一个无效的地址。要记住计算机程序操作的所有内存位数的地址是不可能的。早期的计算机科学先驱们找到了一个绝好的解决办法:创建标志符,例如counter或者sum来指代内存中相关的位。如果存储在一个标志符的值在程序运行期间会发生变化,这个标志符就叫作变量。标志符对于人们编写计算机程序是有意义的,编译器(例如gcc)会把这些标志符转化为地址。最终的计算机程序会操作这些值,并不会看到这些标志。在计算机的内存中,只有地址和值。这是一个在简化编写计算机程序任务方面的主要的早期创新。下图显示了标志和地址之间的关系:
screenshot
考虑下面的示例代码:
screenshot
标志符、地址和值在计算机内存之间的关系可能看起来像这样:
screenshot
程序员不需要控制内存中的地址分配——那是操作系统(例如Linux)和编译器的工作。程序员不需要知道a、b或是z的地址,只需要遵守下面的规则:
screenshot每个数据片段拥有一个唯一的地址。
screenshot地址不允许是0(NULL)或是负数。
screenshot编译器能够把标志符转化为地址。

原文标题:《C语言程序设计进阶教程》一2.1 值和地址

相关文章
|
27天前
|
存储 编译器 C语言
C语言:数组名作为类型、作为地址、对数组名取地址的区别
在C语言中,数组名可以作为类型、地址和取地址使用。数组名本身代表数组的首地址,作为地址时可以直接使用;作为类型时,用于声明指针或函数参数;取地址时,使用取地址符 (&),得到的是整个数组的地址,类型为指向该类型的指针。
|
1月前
|
存储 C语言
C语言:设置地址为 0x67a9 的整型变量的值为 0xaa66
在C语言中,可以通过指针操作来实现对特定地址的访问和赋值。要将地址为 0x67a9 的整型变量值设为 0xaa66,可以先定义一个指向该地址的指针,并通过该指针对该内存位置进行赋值操作。需要注意的是,直接操作内存地址具有一定风险,必须确保地址合法且可写。代码示例应考虑字节序及内存对齐问题。
|
1月前
|
C语言 开发者
C语言实现猜数字小游戏(详细教程)
C语言实现猜数字小游戏(详细教程)
|
1月前
|
编译器 C语言 C++
VSCode安装配置C语言(保姆级教程)
VSCode安装配置C语言(保姆级教程)
|
2月前
|
C语言
C语言程序设计核心详解 第四章&&第五章 选择结构程序设计&&循环结构程序设计
本章节介绍了C语言中的选择结构,包括关系表达式、逻辑表达式及其运算符的优先级,并通过示例详细解释了 `if` 语句的不同形式和 `switch` 语句的使用方法。此外,还概述了循环结构,包括 `while`、`do-while` 和 `for` 循环,并解释了 `break` 和 `continue` 控制语句的功能。最后,提供了两道例题以加深理解。
|
2月前
|
存储 C语言
C语言程序设计核心详解 第十章:位运算和c语言文件操作详解_文件操作函数
本文详细介绍了C语言中的位运算和文件操作。位运算包括按位与、或、异或、取反、左移和右移等六种运算符及其复合赋值运算符,每种运算符的功能和应用场景都有具体说明。文件操作部分则涵盖了文件的概念、分类、文件类型指针、文件的打开与关闭、读写操作及当前读写位置的调整等内容,提供了丰富的示例帮助理解。通过对本文的学习,读者可以全面掌握C语言中的位运算和文件处理技术。
|
2月前
|
存储 C语言
C语言程序设计核心详解 第七章 函数和预编译命令
本章介绍C语言中的函数定义与使用,以及预编译命令。主要内容包括函数的定义格式、调用方式和示例分析。C程序结构分为`main()`单框架或多子函数框架。函数不能嵌套定义但可互相调用。变量具有类型、作用范围和存储类别三种属性,其中作用范围分为局部和全局。预编译命令包括文件包含和宏定义,宏定义分为无参和带参两种形式。此外,还介绍了变量的存储类别及其特点。通过实例详细解析了函数调用过程及宏定义的应用。
|
2月前
|
C语言
C语言程序设计核心详解 第三章:顺序结构,printf(),scanf()详解
本章介绍顺序结构的基本框架及C语言的标准输入输出。程序从`main()`开始依次执行,框架包括输入、计算和输出三部分。重点讲解了`printf()`与`scanf()`函数:`printf()`用于格式化输出,支持多种占位符;`scanf()`用于格式化输入,需注意普通字符与占位符的区别。此外还介绍了`putchar()`和`getchar()`函数,分别用于输出和接收单个字符。
|
2月前
|
存储 算法 C语言
C语言程序设计核心详解 第一章:数制及转换与ASCII码
本专栏旨在夯实C语言基础,涵盖基础知识与进阶内容,助力解决自命题考试和考研问题,为数据结构与算法设计奠定坚实基础。内容包括数制及其转换、ASCII码、内存管理、机器码等,重点讲解二进制、八进制、十六进制的概念与转换方法,并介绍C语言的结构、数据类型和标识符规范。
|
2月前
|
存储 人工智能 C语言
C语言程序设计核心详解 第八章 指针超详细讲解_指针变量_二维数组指针_指向字符串指针
本文详细讲解了C语言中的指针,包括指针变量的定义与引用、指向数组及字符串的指针变量等。首先介绍了指针变量的基本概念和定义格式,随后通过多个示例展示了如何使用指针变量来操作普通变量、数组和字符串。文章还深入探讨了指向函数的指针变量以及指针数组的概念,并解释了空指针的意义和使用场景。通过丰富的代码示例和图形化展示,帮助读者更好地理解和掌握C语言中的指针知识。