C语言高级教程之数组教程

  • C语言高级教程-C语言数组(二)
  • 本文的编译环境
  • 一、前文:C语言数组(一)的链接
  • 二、C语言数组的寻址
    • 2.1 使用寻址运算符"&"
    • 2.2 输出变量地址的格式
  • 三、输出数组里面变量的地址
    • 3.1 输入数组里面存储的数据变量的地址
    • 3.2 "&数组名":代表数组首地址
  • 四、完整程序
    • 4.1 Main.h 文件程序
    • 4.2 Main.c 文件程序
  • 五、总结

C语言高级教程-C语言数组(二)

本文的编译环境

本文的编译环境使用的是集成开发环境:Visual Studio 2019

Visual Studio 2019官网链接如下

Visual Studio 2019官网链接

Visual Studio 2019集成的开发环境的特点有

  • Visual Studio 2019默认安装Live Share代码协作服务。
  • 帮助用户快速编写代码的新欢迎窗口、改进搜索功能、总体性能改进。
  • Visual Studio IntelliCode AI帮助。
  • 更好的Python虚拟和Conda支持。
  • 以及对包括WinForms和WPF在内的.NET Core 3.0项目支持等 。

一、前文:C语言数组(一)的链接

在C语言数组(一)的教程中,简单的介绍了如下的几点

  • 介绍如何在C语言程序中使用数组。
  • 后在编写程序使用数组时,如何通过一个名称来引用一组数值。
  • 通过程序实例来掌握了C语言一维数组的定义,使用方法。

C语言数组(一)的文章链接如下所示

文章:C语言数组(一)

二、C语言数组的寻址

寻址运算符&输出其操作数的内存地址。

  • &:它广泛用于scanf函数。

  • 它放在存储输入的变量名称之前,scanf()函 数就可以利用这个变量的地址,允许将键盘输入的数据存入变量。

  • 只把这个变量名称用作函数的参数,函数就可以使用变量存储的值。

  • 而把寻址运算符放在变量名称之前,函数就可以利用这个变量的地址。

2.1 使用寻址运算符"&"

下面的程序输出一些变量的地址

#define _CRT_SECURE_NO_WARNINGS#include "Main.h"int main()
{system("color 3E");// Define some integer variableslong a = 1L;long b = 2L;long c = 3L;// Define some floating-point variablesdouble d = 4.0;double e = 5.0;double f = 6.0;printf("A variable of type long occupies %u bytes.", sizeof(long));printf("\nHere are the addresses of some variables of type long:");printf("\nThe address of a is: %p  The address of b is: %p", &a, &b);printf("\nThe address of c is: %p", &c);printf("\n\nA variable of type double occupies %u bytes.", sizeof(double));printf("\nHere are the addresses of some variables of type double:");printf("\nThe address of d is: %p  The address of e is: %p", &d, &e);printf("\nThe address of f is: %p\n", &f);system("pause");return 0;
}

按F5进行编译,运行结果如下所示

A variable of type long occupies 4 bytes.
Here are the addresses of some variables of type long:
The address of a is: 00EFFC60  The address of b is: 00EFFC54
The address of c is: 00EFFC48A variable of type double occupies 8 bytes.
Here are the addresses of some variables of type double:
The address of d is: 00EFFC38  The address of e is: 00EFFC28
The address of f is: 00EFFC18
请按任意键继续. . .

声明3个long类型的变量和3个double类型的变量

// Define some integer variables
long a = 1L;
long b = 2L;
long c = 3L;// Define some floating-point variables
double d = 4.0;
double e = 5.0;
double f = 6.0;

2.2 输出变量地址的格式

下来输出long变量占用的字节数,跟着输出这3个变量的地址

printf("A variable of type long occupies %u bytes.", sizeof(long));
printf("\nHere are the addresses of some variables of type long:");
printf("\nThe address of a is: %p  The address of b is: %p", &a, &b);
printf("\nThe address of c is: %p", &c);
  • 使用%u显示sizeof 生成的值,因为它是无符号的整数。
  • 使用一个新的格式说明符%p,来输出变量的地址。
  • 这个格式说明符指定输出一个内存地址,其值为十六进制。内存地址一般是32位或64位,地址的大小决定了可以引用的最大内存量。

输出double变量占用的字节数,接着输出这3个变量的地址

printf("\n\nA variable of type double occupies %u bytes.", sizeof(double));
printf("\nHere are the addresses of some variables of type double:");
printf("\nThe address of d is: %p  The address of e is: %p", &d, &e);
printf("\nThe address of f is: %p\n", &f);
  • 事实上,程序本身不如输出那么有趣。

  • 看看显示出来的地址,地址值逐渐变小,是成“等差排列”,如下图所示。

  • 在本例中,地址b比a低4,c比b低4。这是因为每个long类型的变量占用4个字节。

  • 变量d、e、f也是如此,但它们的差是8。这是因为类型double的值用8个字节来存储。

三、输出数组里面变量的地址

3.1 输入数组里面存储的数据变量的地址

下面的程序将输出数组里面的10变量的地址

 int arrays[10];srand(time(NULL));for (int i = 0; i < 10; i++){arrays[i] = rand() % 20 + 1;}for (int i = 0; i < 10; i++){printf("%d of the address--> %p\n", arrays[i], &arrays[i]);}printf("\n");

按F5进行编译,运行结果如下所示

18 of the address--> 010FFE58
17 of the address--> 010FFE5C
4 of the address--> 010FFE60
15 of the address--> 010FFE64
6 of the address--> 010FFE68
12 of the address--> 010FFE6C
9 of the address--> 010FFE70
3 of the address--> 010FFE74
7 of the address--> 010FFE78
13 of the address--> 010FFE7C请按任意键继续. . .

  • 有地址的变化规律可以看出int类型的地址占四个字节。
  • 数组中存储的数据地址是呈现递增关系。

3.2 “&数组名”:代表数组首地址

&数组名:是取出数组的首个(第一个)数据的地址。
增加代码如下所示

printf("The array of the address is %p\n", &arrays);

按F5进行编译,运行结果如下所示

13 of the address--> 006FFAC8
18 of the address--> 006FFACC
9 of the address--> 006FFAD0
18 of the address--> 006FFAD4
19 of the address--> 006FFAD8
16 of the address--> 006FFADC
17 of the address--> 006FFAE0
7 of the address--> 006FFAE4
17 of the address--> 006FFAE8
17 of the address--> 006FFAECThe array of the address is 006FFAC8
请按任意键继续. . .

  • 可以看出"&数组名"就是将数组中的第一个变量的地址取出来。

四、完整程序

本文的完整程序如下所示

4.1 Main.h 文件程序

#pragma once#include <stdio.h>
#include <stdlib.h>
#include <time.h>

4.2 Main.c 文件程序

#define _CRT_SECURE_NO_WARNINGS#include "Main.h"int main()
{system("color 3E");/*  Define some integer variableslong a = 1L;long b = 2L;long c = 3L;Define some floating-point variablesdouble d = 4.0;double e = 5.0;double f = 6.0;int arrays[10];printf("A variable of type long occupies %u bytes.", sizeof(long));printf("\nHere are the addresses of some variables of type long:");printf("\nThe address of a is: %p  The address of b is: %p", &a, &b);printf("\nThe address of c is: %p", &c);printf("\n\nA variable of type double occupies %u bytes.", sizeof(double));printf("\nHere are the addresses of some variables of type double:");printf("\nThe address of d is: %p  The address of e is: %p", &d, &e);printf("\nThe address of f is: %p\n", &f);*/int arrays[10];srand(time(NULL));for (int i = 0; i < 10; i++){arrays[i] = rand() % 20 + 1;}for (int i = 0; i < 10; i++){printf("%d of the address--> %p\n", arrays[i], &arrays[i]);}printf("\n");printf("The array of the address is %p\n", &arrays);system("pause");return 0;
}

五、总结

  • 本文主要介绍了C语言高级编程的数组的寻址方法。
  • 通过几个实例程序来掌握C语言数组寻址的应用。

本文到这里就结束啦。
希望本文的C语言数组寻址教程能对你有所帮助。

C语言高级教程-C语言数组(二)相关推荐

  1. C语言高级教程-C语言数组(六):变长数组

    C语言高级教程-C语言数组(六):变长数组 一.本文的编译环境 二.一维数组在执行期间确定长度 三.二维数组在执行期间确定长度 四.一维变长数组实例 五.完整程序 5.1 Main.h 文件程序 5. ...

  2. C语言高级教程-C语言数组(三)

    C语言高级教程之数组教程 本文的编译环境 一.前文:C语言数组(一.二)的链接 1.1.C语言数组一文章链接 1.2.C语言数组二文章链接 二.数组的初始化 2.1.数组的初始化的几种方式 三.数组和 ...

  3. 二维数组七行七列C语言,C语言中级教程 再谈数组-7.ppt

    C语言中级教程再谈数组-7ppt课件 * C语言中级培训 七.再谈数组 数组的概念 是一种初级(语言级)形式的数据结构. 数组的特点 无名: 连续: 有序: 等大小: 个数固定(除了在堆上分配): 数 ...

  4. c++ 结构体赋值_《零基础看得懂的C语言入门教程》—(十二)结构体是这么回事

    一.学习目标 了解C语言的结构体的使用方法 了解C语言结构体的结构的赋值 了解多种C语言结构体变量的赋值方法和取值方法 目录 <零基础看得懂的C语言入门教程>--(二)简单带你了解流程 & ...

  5. 《量化金融R语言高级教程》一2.2 在R中建模

    本节书摘来异步社区<量化金融R语言高级教程>一书中的第2章,第2.2节,作者: [匈牙利]Edina Berlinger(艾迪娜•伯林格) , 等 译者: 高蓉 责编: 胡俊英,更多章节内 ...

  6. 《量化金融R语言高级教程》一1.2 波动率建模

    本节书摘来异步社区<量化金融R语言高级教程>一书中的第1章,第1.2节,作者: [匈牙利]Edina Berlinger(艾迪娜•伯林格) , 等 译者: 高蓉 责编: 胡俊英,更多章节内 ...

  7. 《量化金融R语言高级教程》一2.1 套利定价理论

    本节书摘来异步社区<量化金融R语言高级教程>一书中的第2章,第2.1节,作者: [匈牙利]Edina Berlinger(艾迪娜•伯林格) , 等 译者: 高蓉 责编: 胡俊英,更多章节内 ...

  8. 《量化金融R语言高级教程》一1.4 参考文献

    本节书摘来异步社区<量化金融R语言高级教程>一书中的第1章,第1.4节,作者: [匈牙利]Edina Berlinger(艾迪娜•伯林格) , 等 译者: 高蓉 责编: 胡俊英,更多章节内 ...

  9. 计算机编程c 语言实型数据,C语言-基础教程-C语言实型数据

    C语言-基础教程-C语言实型数据 分类:计算机等级 | 更新时间:2016-07-08| 来源:转载 2.4.1 实型常量 实型常量又称浮点常量,是一个十进制表示的符号实数.符号实数的值包括整数部分. ...

最新文章

  1. liunx 学习笔记-wzq
  2. c语言既适合于开发,C语言试题及答案 (1)
  3. 信号量与条件变量的区别
  4. Spring Boot 配置线程池使用多线程插入数据
  5. python中的json注意事项
  6. 程序员在35-40岁之后真的就是死胡同吗?
  7. 用随机梯度下降来优化人生
  8. 怎么访问原生php类,关于如何利用php的原生类进行XSS
  9. Hibernate 中upate,savaOrUpdate,merge的区别
  10. ERP选型需把握主动权!
  11. 注意!JWT不是万能的,入坑需谨慎!
  12. 我的大学十年——林锐
  13. java编程实现食堂饭卡刷卡_食堂饭卡管理系统设计方案报告.docx
  14. 2015广州国际游博会:关于手游安全的那些事儿
  15. 虚拟机ip映射到外网
  16. 元素周期表排列的规律_元素周期表中的几个规律
  17. 耐摔 8寸 android,屏幕耐摔的手机有哪些?6款屏幕耐摔的手机推荐
  18. rpcx服务框架浅析9-序列化
  19. was连接oracle rac集群,oracle 11g rac 集群操作命令
  20. 一个机器人,主要由哪几部分组成?

热门文章

  1. HEIC图片如何快速转换格式
  2. 《计算机科学与工程导论:基于IoT和机器人的可视化编程实践方法第2版》一2.2.2 VIPLE的活动和服务...
  3. 编写一个shell脚本,可以在屏幕上打印出笛卡尔曲线
  4. 领航优配|大行总资产增速在狂飙 净息差一路踩点刹
  5. 公司电脑监控软件如何管控员工上网行为?
  6. 记录--用JS轻松实现一个录音、录像、录屏的工具库
  7. 写了个魔兽争霸辅助工具
  8. spark报错:value xxx is not a member of Any
  9. win10间歇性闪屏_Win10桌面屏幕不断忽闪忽现出现闪屏bug该怎么办
  10. 精通三菱PLC新一代iQ-R可编程控制器