【C语言】 数组:-- 一维数组 -- 二维数组 -- 数组越界 -- 数组作为函数的参数2

简介: 【C语言】 数组:-- 一维数组 -- 二维数组 -- 数组越界 -- 数组作为函数的参数2

我们来想想 string 的特点与 sizeof 的特点:


1.string 是一个库函数,是用来计算字符串长度的。它只针对字符串的 '\0' 前的字符。


2.sizeof 是单目操作符(运算符),是用来求类型或者变量所占空间大小(单位是字节)。它是对任何类型都可以进行计算,只管空间大小。


以此为基础,我们再来对这段代码进行分析:



因此打印出来的值就是4 3,3 乱码。

我们可以对两个数组进行打印一下再看看效果:

字符串的结束标志是 '\0' ,而arr1并没有 '\0' ,所以打印出来就是乱码。

2.3 一维数组的使用

对于数组的使用,我们之前介绍了一个操作符:[ ],下标引用操作符。它其实就是数组访问的操作符。

我们来看看代码:

#include <stdio.h>
int main()
{ 
  int arr[10] = { 0 };//数组的不完全初始化,这里的[]是语法
  //计算数组的元素个数
  int sz = sizeof(arr) / sizeof(arr[0]);
  int i = 0;//做下标
  for (i = 0; i < 10; i++)
  {
    arr[i] = i;//这里的[]才是操作符
  }
  //输出数组内容
  for (i = 0; i < 10; i++)
  {
    printf("%d ", arr[i]);
  }
  return 0;
}

我们在展示效果之前来想想下面的知识:

2.3.1 数组的下标

下标是用来访问元素的

int arr[10] = { 1,2,3,4,5,6,7,8,9,0 };
//下标      0 1 2 3 4 5 6 7 8 9

数组的大小可以用 sizeof 来求

int sz = sizeof(arr) / sizeof(arr[0]);
//        40   /   4

基于以上知识,我们对代码进行分析


2.4 一维数组在内存中的存储

我们来看代码

#include <stdio.h>
int main()
{ 
  int arr[10] = { 0 };
  int i = 0;
  for (i = 0; i < 10; i++)
  {
    printf("arr[%d] = %p\n", i, &arr[i]);
  }
  return 0;
}

效果展示:

int 是整形,一个整形是 4 个字节,每次加一都是跳过一个整形(4个字节),所以地址每次都是加 4 。

仔细观察输出的结果,我们知道,随着数组下标的增长,元素的地址,也在有规律的增长:

一维数组在内存中是连续存放的,地址会随下标的增长而增长。

我们再看一段代码

#include <stdio.h>
int main()
{ 
  int arr[10] = { 0 };
  int* p = &arr[0];
  int i = 0;
  for (i = 0; i < 10; i++)
  {
    printf("%p == %p\n", p+i, &arr[i]);
  }
  return 0;
}

效果展示:

我们可以看到两种取地址的方法取出的地址是一样的,这是为什么呢?

A:p 取出来的地址是数组首元素的地址,p 的类型是 int (整形),+1相当于跳过了四个字节,所以和使用下标访问操作符取出的地址是一致的。

总结:定义的是什么类型的指针,+1就跳过一个什么类型的元素(对应跳过类型一个字节)。

如果我们对 p+i 解引用操作就会找出相对应位置的元素

效果展示:


相关文章
|
2月前
|
存储 C语言
`scanf`是C语言中用于按格式读取标准输入的函数
`scanf`是C语言中用于按格式读取标准输入的函数,通过格式字符串解析输入并存入指定变量。需注意输入格式严格匹配,并建议检查返回值以确保读取成功,提升程序健壮性。
848 0
|
4月前
|
安全 C语言
C语言中的字符、字符串及内存操作函数详细讲解
通过这些函数的正确使用,可以有效管理字符串和内存操作,它们是C语言编程中不可或缺的工具。
285 15
|
9月前
|
存储 人工智能 Java
一文彻底搞定C语言中的二维数组
本文详细介绍了C语言中的多维数组,包括二维和三维数组的定义、初始化方式、内存布局及遍历方法。通过具体示例讲解了多种赋值技巧,并强调了数组在内存中按行存放的特点。希望这些内容能帮助你在编程路上不断成长!君志所向,一往无前!
506 1
一文彻底搞定C语言中的二维数组
|
9月前
|
人工智能 Java 程序员
一文彻底搞清楚C语言的函数
本文介绍C语言函数:函数是程序模块化的工具,由函数头和函数体组成,涵盖定义、调用、参数传递及声明等内容。值传递确保实参不受影响,函数声明增强代码可读性。君志所向,一往无前!
294 1
一文彻底搞清楚C语言的函数
|
9月前
|
存储 人工智能 程序员
一文彻底搞明白C语言的数组
本文详细介绍了C语言中的数组,包括定义、初始化(静态与动态)、存储方式、访问方法及常用操作,如遍历、修改元素和作为函数参数传递。数组是C语言中最基本的数据结构之一,掌握它对编程至关重要。下篇将介绍二维数组,敬请期待!
422 0
一文彻底搞明白C语言的数组
|
10月前
|
存储 编译器 C语言
【C语言程序设计——函数】分数数列求和2(头歌实践教学平台习题)【合集】
函数首部:按照 C 语言语法,函数的定义首部表明这是一个自定义函数,函数名为fun,它接收一个整型参数n,用于指定要求阶乘的那个数,并且函数的返回值类型为float(在实际中如果阶乘结果数值较大,用float可能会有精度损失,也可以考虑使用double等更合适的数据类型,这里以float为例)。例如:// 函数体代码将放在这里函数体内部变量定义:在函数体中,首先需要定义一些变量来辅助完成阶乘的计算。比如需要定义一个变量(通常为float或double类型,这里假设用float。
274 3
|
C语言 存储 C++
《C语言及程序设计》实践项目——二维数组与指针
返回:贺老师课程教学链接 【项目1-二维数组当函数参数】定义一个函数来完成对参数数组中元素的求和工作,函数声明如下:int sum(int array[ ][4],int m,int n); //该函数完成对array数组中的前m行和n列元素求和在以下程序的基础上,完成对sum函数的定义。#include &lt;stdio.h&gt; int sum(int array[ ][4],in
1459 0
|
存储 C语言
《C语言及程序设计》实践项目——二维数组
返回:贺老师课程教学链接 【项目1-折腾二维数组】创建一个5行4列的二维整型数组,通过初始化,为数组中的前两列的10个元素赋初值,然后: 通过键盘输入,使后两列的10个元素获得值; 按行序优先输出数组元素; 将所有元素值乘以3后保存在数组中; 按列序优先输出(输出的第一行是数组中的第一列……,其实输出的就是“转置”); 将数组“倒”着输出(即最后一行最后一列的最先输出,第0行第0列的最后输出
1576 0
|
10月前
|
存储 算法 C语言
【C语言程序设计——函数】素数判定(头歌实践教学平台习题)【合集】
本内容介绍了编写一个判断素数的子函数的任务,涵盖循环控制与跳转语句、算术运算符(%)、以及素数的概念。任务要求在主函数中输入整数并输出是否为素数的信息。相关知识包括 `for` 和 `while` 循环、`break` 和 `continue` 语句、取余运算符 `%` 的使用及素数定义、分布规律和应用场景。编程要求根据提示补充代码,测试说明提供了输入输出示例,最后给出通关代码和测试结果。 任务核心:编写判断素数的子函数并在主函数中调用,涉及循环结构和条件判断。
469 23
|
10月前
|
算法 C语言
【C语言程序设计——函数】利用函数求解最大公约数和最小公倍数(头歌实践教学平台习题)【合集】
本文档介绍了如何编写两个子函数,分别求任意两个整数的最大公约数和最小公倍数。内容涵盖循环控制与跳转语句的使用、最大公约数的求法(包括辗转相除法和更相减损术),以及基于最大公约数求最小公倍数的方法。通过示例代码和测试说明,帮助读者理解和实现相关算法。最终提供了完整的通关代码及测试结果,确保编程任务的成功完成。
375 15
【C语言程序设计——函数】利用函数求解最大公约数和最小公倍数(头歌实践教学平台习题)【合集】