首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

C 语言数组 ( 数组相关地址 | 数组首元素地址 | 数组地址 )

文章目录 一、数组相关地址 1、数组首元素地址 2、数组地址 二、代码示例 一、数组相关地址 ---- 数组首元素地址数组地址 值相等 ; int array[10]; 其中 array + 1...值是 array 地址 加上 4 字节 ; 其中 &array + 1 值是 array 地址 加上 40 字节 ; 1、数组首元素地址 数组首元素地址 : 数组名 , 就是 数组元素首地址..., 该值 是一个常量 , 不能被修改 , 一定程度上 等同于 常量指针 ; 数组名 常量 : 变量 本质 是 内存空间别名 , 一旦变量被声明 , 就必须为该变量分配对应内存 , 内存一旦分配 , 就是固定...; 如 : 在函数中定义 如下 局部变量 , 该数组一旦声明 , 就可以知道这是一个 40 字节内存 , 已经在 栈内存分配完毕 , 数组地址肯定就不能修改了 ; int array[10];...2、数组地址 数组地址 : 下面的数组张红 ,&array 是数组地址 ; int array[10]; 二、代码示例 ---- 代码示例 : #include #include

8.9K20

C语言数组当参数传递

在学习C语言过程中遇到数组作为参数传递问题 一维数组: #include int test2(int a[]){ for(int i=0;i<5;i++){ printf...,(单向)但是数组传递时候是地址传递,只要形参发生了变化,实参也会发生变化(双向)。...这样传递数组就会发现一个问题,我没有办法获取到数组长度。...因为,a是函 数参数,到了本函数中,a只是一个指针(地址,系统在本函数运行时,是不知道a所表示地址有多大数据存储 空间,这里只是告诉函数:一个数据 空间首地址 ),所以,sizoef(a)结果是指针变量...我可以在初始化数组地方获取到数组长度,作为参数传递过来: int test2(int a[],int n){ for(int i=0;i<n;i++){ printf("%d ",a[i]);

2K30
您找到你想要的搜索结果了吗?
是的
没有找到

C语言数组名取地址

大家好,又见面了,我是全栈君,祝每个程序员都可以多学几门语言。 作者 : 卿笃军 你有没有想过,对一个一维数组名取地址,然后用这个地址进行加减运算。这会出现什么样结果呢?...答:a是一个一维数组名字,&a相当于一个指向一维数组指针。怎么感觉这么熟悉?指向数组指针,那不就是行指针吗?int (*p)[]。...答:上面不是说了嘛,&a就是一个行指针,那就是指向一行指针咯。...行指针+1,不就指向下一行了,这里一行为[5]个,那么int *p = (int *)(&a+1)就要在a基础上偏离5个位置:(例如以下:上一行表示偏离位数,下一行表示a[]中相应数据) 0 1...移动五位都跑出a[]数组处于’ * ‘号位置了。哦,我看到printf()输出了。你输出是*(p-1),这里p是一个单指针-1就是往左位移一位即可了,那不就是又回到5位置了吗?

1.6K20

Go语言函数间传递数组问题

大家都知道,Go 语言中,数组是分配连续内存,也就是说,在函数中传递一个大数组,代价是很高,例如: // 声明了一个8 MB 数组 // 8 * 10^8 = 8 * 100000000 Bit...array := [1e6]int // 将入有个 foo() 函数 foo(array) 这样的话,每次调用 foo() 函数时候,都会在栈上分配8 MB 内存,因为函数之间传递变量时,是值传递...,也就是不管这个变量数组有多大,都会完整复制,然后传递给函数。...如下: // 声明了一个8 MB 数组 // 8 * 10^8 = 8 * 100000000 Bit array := [1e6]int // 将入有个 foo() 函数 foo(&array)...这样开销就小得多了,因为这个参数其实是将数组地址传入了函数,而不是数组本身值,而一个内存地址,只需要在展示栈上分配8个字节就够用了。

1K20

C语言系列】C语言数组

Int x[]={1,2}; Char ca[5]={‘a’,‘A’,‘B’,‘C’,‘D’}; 数组名即代表数组地址数组地址==数组名(ca)==数组首元素地址&ca[0] 在内存中,内存从大到小进行寻址...,为数组分配了存储空间后,数组元素自然从上往下排列存储,整个数组地址为首元素地址。...模拟该数组内存存储细节如下: ? 注意:字符在内存中是以对应ASCII值二进制形式存储,而非上表形式。 在这个例子中,数组x地址为它首元素地址0x08,数组ca地址为0x03。...0; } Array数组与ages数组地址一致,若以数组作为函数参数,这种传递方式是传址调用,传递是整个数组地址,修改形参数组元素值,就是修改实参值。...提示:数组作为一个函数参数时,如果函数体涉及到数组遍历等操作,通常把数组实际元素个数也作为参数传递给函数。

28.5K61

C语言数组

C 语言支持数组数据结构,它可以存储一个固定大小相同类型元素顺序集合。数组是用来存储一系列数据,但它往往被认为是一系列相同类型变量。...数组特定元素可以通过索引访问。 所有的数组都是由连续内存位置组成。最低地址对应第一个元素,最高地址对应最后一个元素。 ?...声明数组C 中要声明一个数组,需要指定元素类型和元素数量,如下所示: type arrayName [ arraySize ]; 这叫做一维数组。...arraySize 必须是一个大于零整数常量,type 可以是任意有效 C 数据类型。...初始化数组C 中,您可以逐个初始化数组,也可以使用一个初始化语句,如下所示: double balance[5] = {1000.0, 2.0, 3.4, 7.0, 50.0}; 大括号 { }

5K10

C 语言】数据类型本质 ( 数据类型 | 数据类型本质 | 数组地址 | 数组首元素地址 )

文章目录 一、数据类型 二、数据类型本质 ( 数组地址 | 数组首元素地址 ) 一、数据类型 ---- " 数据类型 " 是 数据抽象 ; 相同类型数据 , 表示形式相同 , 存储格式相同 , 相关操作相同...; C 语言程序中 数据 , 必定属于某种 数据类型 ; 数据类型分为 简单数据类型 和 复杂数据类型 ; 简单数据类型 : 基本数据类型 : C 语言中有 6 种基本数据类型 ;...C 语言编译器 分配 40 直接内存 ; 打印上述数组 array , array + 1 , &array , &array + 1 值 , #include int main..., 但是这二者所代表数据类型不同 ; array 代表 数组首元素地址 ; &array 代表 数组地址 ; array + 1 与 &array + 1 值相差 40 字节 , 也就是整个数组大小...; array + 1 表示 数组首元素地址 加上一个 数组元素 占据内存大小 ; &array + 1 表示 数组地址 加上一整个 数组 占据内存大小 ; 数组数据类型 : 定义 数组类型 定义

2.1K10

c语言_数组

数组 1、数组定义和使用 格式: 数据类型 数组名[元素个数] 元素个数,代表该数组有多少个相同数据类型变量 下标 用来表示数组某一个元素 例如 int arr[10]; arr[1]代表数组第二个元素...int 个数 = sizeof(数组名)/sizeof(数组元素 | 数组数据类型) 求出数组地址: printf("%p\n",数组名) printf("%p\n",数组元素) 数组元素+1 (sizeof...(数据类型)) 数组名+1(sizeof(数组名)) 练习:十只小猪称体重 定义一个数组 存储小猪体重 通过遍历找到最重小猪 找到数组中数据最大值下标 根据下标打印数据 练习: 找到小猪中第二重...)/sizeof(数组名[0]); 求列数:sizeof(数组名[0])/sizeoef(数组名[0][0]) 二维数组地址表示方式: printf("%p\n",数组名); 练习:10名学生 三门成绩...中就是数字0 ​ printf("%s", arr); ​ //for (int i = 0; i < 10; i++) ​ //{ ​ // printf("%c", arr[i]); ​ //} ​

4.5K20

C语言——数组

a,数组下标 C语言中,数组下标是从0开始,如果有n个元素,则第一个元素下标为0,最后一个元素下标为n-1 ,下面举例: 对于:            int arr [5] = {1,2,3,4,5...}; 数组元素:           1   2   3  4   5  对应下标:           0   1   2   3  4   C语言中 [ ] 是“下标引用操作符” ,...+) {          printf("%d",arr[i]); }  c,储存 这里主要讲下数组元素在内存中储存特点: 我们先用一下代码来依次打印出一维数组里元素地址: 得到: 由上述打印出地址...,我们可以得出,数组在内存储存特点是: 1,数组随下标的增长,地址由小变大 2,并且每两个相邻元素之间相差4(即一个整形大小:4个字节) 三,二维数组 (1)了解二维数组 如果我们把一维数组当做数组元素...储存 用同样打印方法,我们来观察二维地址特点: 不难发现,和一维数组所得出结论应该一致: 1,数组随下标的增长,地址由小变大 2,并且每两个相邻元素之间相差4(即一个整形大小:4个字节) 四,

11310

C语言-数组

数组介绍 C语言数组是一个同类型数据集合,主要用来存储一堆同类型数据。 程序里怎么区分是数组?[ ] 这个括号是数组专用符号. 定义数组、 访问数组数据都会用到。...数组在定义之后就无法更改大小。 4. 数组空间是连续—内存。 5. 数组名称就是数组空间地址。 6. 数组初始化时,如果没有赋值,那么数组空间里数据是未知---局部变量。 7....数组定义语法与注意事项 1. 数组名称是数组元素地址。(数组名字就是地址) 2. 数组只能在初始化时候进行整体赋值。比如: int a[100]={10,20,30}; 3....数组下标访问是从0开始。比如: int a[10]; 下标范围: a[0] ~ a[9] 4. 数组名称虽然是地址,但是这个地址是不能偏移、也不能自增自减,也不能改变指向。...数组定义时候(C89), 数组下标里大小只能填常量。

4K10

C语言数组——字符数组

字符数组 字符数组顾名思义就是数组元素类型为字符型数组。特殊之处在于它是数组元素为字符数组。其定义一般形式和注意事项与之前讲解一般数组类似,只是其中类型说明符是char。...}; for (i = 0; i < SIZE; i++) { printf("%c", arr[i]); } return 0; } 运行结果: 运行结果为“Hello...看看上面代码中定义arr数组,其数组长度为20,而初始化字符元素个数为12,初始化字符元素个数小于数组长度,编译器在编译过程中将后面没有初始化数组元素赋值为‘\0’,这也正是打印输出中含有空字符原因...='\0'; i++) { printf("%c", arr[i]); } return 0; } 运行结果: 这时输出结果中就不含有任何空字符了,因为巧妙地使用了字符数组...= '\0'; i++) { printf("%c", arr[i]); } return 0; } 运行结果: 在对一维字符数组进行定义和初始化过程中,可以不指定其长度。

7.3K20

C语言数组——字符数组

C语言目录 C/C++学习资源(百度云盘链接) 计算机二级资料(过级专用) C语言学习路线(从入门到实战) 编写C语言程序7个步骤和编程机制 C语言基础-第一个C程序 C语言基础-简单程序分析...VS2019编写简单C程序示例 简单示例,VS2019调试C语言程序 C语言基础-基本算法 C语言基础-数据类型 C语言输入输出函数 C语言流程控制语句 C语言数组——一维数组...C语言数组——二维数组 前面两篇文章分别介绍了一维数组和二维数组,今天我们一起看看字符数组 字符数组 字符数组顾名思义就是数组元素类型为字符型数组。...特殊之处在于它是数组元素为字符数组。其定义一般形式和注意事项与之前讲解一般数组类似,只是其中类型说明符是char。...如果您觉得本篇文章对您有帮助,请转发给更多的人 【C语言中文社区】是一个C语言视频教程、学习笔记、电子书、计算机二级资料等专注于C语言编程学习者干货知识分享平台,精选深度文章,分享优秀干货类、技能类学习资源

6.1K40

c语言如何遍历数组,C语言数组遍历

C语言数组遍历教程 C语言for循环遍历数组详解 语法 for (i = 0; i < count; i++) { // arr[i] } 说明 其中 count 是数组元素个数,此时,数组每一个元素是...C语言while循环遍历数组详解 语法 int i = 0; while(i < count) { // arr[i] i++; } 说明 其中 count 是数组元素个数,此时,数组每一个元素是...C语言do while循环遍历数组详解 语法 int i = 0; do { // arr[i] i++; }while(i < count); 说明 其中 count 是数组元素个数,此时,数组每一个元素是...arr[i],注意每次遍历完之后,一定要加 i 值加一,同时,我们一定要先访问数组元素,再次将变量 i 加一,顺序不能错。...C语言数组遍历总结 C 语言数组遍历,有三种方式,分别为:通过 for 循环遍历,通过 while 循环遍历与通过 do while 循环遍历方式。

6.8K20

c++:*与&, *&p, 指针传递,引用传递数组形参

(&p) = p p是指针,&p为p地址 (取包有内容p盒子编号) 再进行解引用(拆开盒子),所以得到 *&p = p 指针传递 形参出现在函数定义中,在整个函数体内都可以使用, 离开该函数则不能使用...\n”; } 形参int *p ,实参为传入地址 引用传递 void test(int &a) { a += 3; cout << “a值:” << a << “\n” << “a地址:” <...n”; } 相当于变量别名,函数内后续任何改变都会影响原变量 数组形参 当要使用数组作为函数形参时,因为一个数组不能使用另外一个数组初始化,也不能将一个数组赋值给另外一个数组,而在“1.1 非引用形参...”中提到要用实参副本来初始化形参,所以实参为数组时,不能直接传递给形参。...FindMax(int array[10]); 虽然不能直接传递数组,但是函数形参可以写成数组形式。

24520
领券