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

C语言-数组名与&数组名的细节注意

这篇博客将通过整型数组、字符数组、字符串放在数组中、以及二维数组的数组名与&数组名和各类特殊情况的题目讲解来使得我们对于指针与数组名具有更加深刻的了解。...注意: sizeof(数组名) - 数组名表示整个数组的-计算的是整个数组的大小 &数组名 - 数组名表示整个数组,取出的是整个数组的地址 除此之外,所有的数组名都是数组首元素的地址 !!!...1.整型数组 //sizeof(数组名) - 数组名表示整个数组的-计算的是整个数组的大小 //&数组名 - 数组名表示整个数组,取出的是整个数组的地址 //除此之外,所有的数组名都是数组首元素的地址...char arr[] = {'a','b','c','d','e','f'}; printf("%d\n", sizeof(arr));//6 printf("%d\n", sizeof(arr+0))...arr[1]也是同样的道理 3.字符串放在数组中 char arr[] = "abcdef"; printf("%d\n", sizeof(arr));//7,该种方式数组里面存放的是:[a b c d

9000

C语言 对数组名取地址

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

1.7K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    彻底弄懂C语言数组名

    数组名不是指针,但大多数使用到数组名的地方,编译器都会把数组名隐式转换成一个指向数组首元素的指针来处理。...(出自《C和指针》第141页) 这里需要补充两点,&a的类型和二维数组名的类型。...然后二维数组的类型同样取决于数组元素的类型,假设有二维数组int b[10][20] 因为C语言的多维数组实际上是一维数组,二维数组实际上只是一个一维数组,只不过里面每个元素又是一个一维数组而已。...a 的值是数组首元素的地址,它并不是一个指针。 “取一个数组名的地址所产生的是一个指向数组的指针,而不是一个指向某个指针常量值的指针”(出自《C和指针》第142页)。...这在C++里称为尾后指针。

    61720

    【C语言】数组名及其地址的理解与应用

    C语言作为一种底层编程语言,强大之处在于它可以直接操作内存。数组作为一种常见的数据结构,在C语言中被广泛使用。数组名的理解和使用,对于掌握指针、内存管理等底层概念具有重要意义。...本文将通过实际代码与分析,帮助读者更深入理解C语言中数组名的本质及其与数组元素地址的关系,并通过具体例子探讨如何正确地使用数组名以及指针操作。 C语言 数组名的本质 1....数组名实际上是一个指向第一个元素的指针 在C语言中,数组名并不是一个简单的变量名,而是数组首元素的地址。数组名本质上是一个常量指针,指向数组的第一个元素。...这里的关键是理解数组名并不是数组的“名字”,而是数组第一个元素的地址。 2. 数组名与数组首元素地址的关系 数组名本质上就代表了数组第一个元素的地址,这一关系在C语言中非常重要。...通过对比,sizeof(&arr[0]) 和 sizeof(arr) 得到的结果显然不同。 小结 本文通过多个代码示例分析了C语言中数组名的本质以及它在内存中的表现。

    8710

    C++数组名a和&a的区别

    下面说说a和&a的区别,说完了,再看该题的结果。 C/C++里面的数组名字会退化为指针,所以数组名a实际指的是数组的第一个元素的地址。...而数组名作为指针来讲有特殊性,它正在它所指向的内存区域中,&a的值和a的数值是相同的(可以输出观察一下),但是类型和意义不同。而指针的加法操作和指向的数据类型密切相关。...但是&a的类型则相当于int **,是所谓指向数组的指针,是数组元素类型的二级指针,对它加1是相当于 &a + 1 * sizeof(a)的,所以会偏移一个数组长度。...现在来看程序,&a + 1其实偏移了一个数组的长度即就是6,其实在VS中通过调试可以查看&a + 1的类型,其类型为int[5] *,所以(int*)(&a + 1)将其强制转成int *类型。...这里应该很明显了a + 1指向的是数组a的第二个元素,p指向的是数组后面的元素(这里我们不知道它是多少),p - 1则指向数组的最后一个元素!  所以程序运行的结果为3 6.

    1K50

    【C语言----数组详解】

    数组的声明 在C语言中,声明数组需要指定以下信息: 数据类型: 数组中元素的数据类型,例如 int、float、char 等。 数组名: 数组的名称,遵循变量命名规则。...实现字符串: C语言中,字符串实际上是以字符数组的形式存储的。 作为函数参数: 可以将数组作为参数传递给函数,以便在函数内部对数组进行操作。...六、多维数组 C语言支持多维数组,例如二维数组、三维数组等。多维数组可以理解为数组的数组。...int element = matrix[1][2]; // element = 6 七、总结 数组是C语言中非常重要的数据结构,掌握数组的使用对于编写高效、简洁的代码至关重要。...本文 介绍了数组的基本概念、声明和初始化方法、元素的访问和遍历、常见应用场景以及多维数组等内 容。希望读者能够通过本文的学习,对C语言数组有一个更深入的理解,并能够灵活运用数组解决

    9110

    【C语言----函数详解】

    引言 在C语言编程中,函数扮演着至关重要的角色。它如同乐高积木,将复杂的程序分解成一个个独 立、可重复使用的模块,使代码更加简洁、易读、易维护。...本文将深入浅出地讲解C语言函数,带 你领略其魅力,掌握其精髓。 一、函数是什么 函数是完成特定任务的独立代码块,它接收输入参数,执行特定操作,并返回结果。...int result = add(10, 20); // 调用 add 函数,并将返回值存储在 result 中 四、函数参数传递 C语言中,函数参数传递有两种方式: 值传递: 将实际参数的值复制一份传递给形式参数...typedef int (*func_ptr)(int, int); // 使用函数指针调用函数 func_ptr f = add; int result = f(10, 20); 八、总结 函数是C语言编程中不可或缺的工具...希望读者能够通过本文的学习,对C语言函数有一个更深入的 理解,并能够灵活运用函数编写出更加高效、简洁的代码。

    11800

    详解C语言中的数组

    1.序言 在正式讲解C语言数组之前,我们可以先了解一下,为什么出现数组这种自定义的数据类型? 其实想解决这个问题,非常的简单!...但是,我们该如何从数组中读出我们出入的数据呢? 这部分的知识比较重要! 4.1 数组下标 C语言规定数组是有下标的,并且 下标是从0开始的(这个点一定要记住,新手特别容易犯错的点!)。...如下: int arr[10] = {1,2,3,4,5,6,7,8,9,10}; 在C语言中提供了一种的操作符 —— [] ,这个运算符就做下标引用操作符。...那就得请出本知识点的主角“sizeof”操作符。 sizeof操作符是C语言的一个关键字,是可以计算类型或者变量的大小的,其实sizeof也可以计算数组的大小。单位是字节。...希望这篇文章能够帮助读者们学习C语言。让我们一起进步吧!!!✌️✌️✌️

    12710

    C语言中的指针详解

    什么是指针 C语言中指针是一种数据类型,指针是存放数据的内存单元地址。...C语言规定,变量地址只能通过取地址运算符获得,即“&”,其运算对象是变量或数组元素名,运算结果是对应变量或数组元素的地址。...需要注意的是,虽然地址是一个整数,但是C语言中不允许把整数看成“地址常量”,所以此处的“地址型表达式”不能是整数。 2. 使用指针变量 格式:指针变量名 需要使用地址时,可以直接引用指针变量名。...='\0';string++){ printf("%c",*string); // I love China }; return 0; } C语言中,字符串是按字符数组进行处理的...形参为指针变量、实参为数组名; 4. 形参为数组名、实参为指针变量 C语言中,函数可以返回整型、实型、字符型数据,也可以返回指针类型数据,即返回一个地址。

    2.9K20

    【C语言】函数详解

    例如y=x+1,给x赋一个值,你将得到一个y的值,y的值随着x值的改变而改变。 在C语言中有着相似的理解对于函数。...函数可以作为一段实现某一特定功能的代码,可以像控制x值改变y值那样进行某些传参操作。 在了解完函数的概念后,下面来了解下C语言中一般常见的两种函数。...也就是说,标准函数库是由编译器的发行厂商制作时进行添加的,每个编译器的库函数内容可能不一样,但是功能是按照C语言标准制作的,功能实现效果和方法几乎是一样的。...关于库函数的相关头文件的查询可以在C/C++官网或Cplusplus进行查询 。...https://zh.cppreference.com/w/c/header cplusplus.com/doc/ 在reference页面即可选择C library进行查看C语言库函数所在头文件信息

    12810

    C 语言指针详解

    指针pp为指向指针p的指针 定义指针变量 C语言中,定义变量时,在变量名 前 写一个 * 星号,这个变量就变成了对应变量类型的指针变量。必要时要加( ) 来避免优先级的问题。...引申:C语言中,定义变量时,在定义的最前面写上typedef ,那么这个变量名就成了一种类型,即这个类型的同义词。...在C语言中,我们让指针变量赋值为NULL表示一个空指针,而C语言中,NULL实质是 ((void*)0) ,  在C++中,NULL实质是0。...数组所占存储空间的内存:sizeof(数组名) 数组的大小:sizeof(数组名)/sizeof(数据类型),在32位平台下,无论指针的类型是什么,sizeof(指针名)都是 4 ,在 64 位平台下,...函数与指针 函数的参数和指针 C语言中,实参传递给形参,是按值传递的,也就是说,函数中的形参是实参的拷贝份,形参和实参只是在值上面一样,而不是同一个内存数据对象。

    2.5K11

    【C语言】递归详解

    1.前言 这次博客内容是与递归有关,递归是学习C语⾔函数绕不开的⼀个话题,那什么是递归呢?接下来正⽂开始。 2. 递归的定义 递归其实是一种解决问题的方法,在C语言中,递归就是函数自己调用自己。...来看看一个简单的C语言递归代码 #include int main() { printf("hehe\n"); main();//main函数中⼜调⽤了main函数 return...在C语言中每一次函数调用,都要需要为本次函数调用在栈区申请⼀块内存空间来保存函数调用期间的各种局部变量的值,这块空间被称为运行时堆栈,或者函数栈帧。...当n大于2时就要实现前面两个数字,就要相加,然后将a和b都向后挪,也就是将b的值给a,c的值给b,然后再执行a+b,每执行一次n都要减减一下。...int Fib(int n) { int a = 1; int b = 1; int c = 1; while (n>2) { c = a + b; a = b; b = c;

    79210

    【C语言】结构体详解 -《探索C语言的 “小宇宙” 》

    C语言结构体(struct)详解 结构体概览表 功能 描述 定义结构体 定义一个结构体类型 声明结构体变量 声明一个结构体变量 访问成员 使用点运算符(.)和箭头运算符(->)访问成员 初始化结构体 在声明时初始化结构体...Height: %.2f\n", person2.height); return 0; } 输出 Name: Alice Age: 30 Height: 160.00 3.2 使用指定初始化器 C99...结构体的内存对齐 结构体的内存对齐与填充是为了提高数据访问的效率。在C语言中,结构体的内存布局可能会受到对齐要求的影响,导致结构体的实际大小可能大于成员变量总和的大小。...8.1 对齐示例 #include struct Example { char c; // 1 byte int i; // 4 bytes...结束语 本节内容已经全部介绍完毕,希望通过这篇文章,大家对C语言中的结构体 struct 有了更深入的理解和认识。

    19210

    再谈C语言——C指针详解

    我们指知道:C语言中的数组是指 一类 类型,数组具体区分为 int 类型数组,double类型数组,char数组 等等。...必要时要加( ) 来避免优先级的问题。 引申:C语言中,定义变量时,在定义的最前面写上typedef ,那么这个变量名就成了一种类型,即这个类型的同义词。...在C语言中,我们让指针变量赋值为NULL表示一个空指针,而C语言中,NULL实质是 ((void*)0) , 在C++中,NULL实质是0。...C语言中,实参传递给形参,是按值传递的,也就是说,函数中的形参是实参的拷贝份,形参和实参只是在值上面一样,而不是同一个内存数据对象。...既然是存放在内存中,那么函数也是有自己的指针的。 C语言中,函数名作为右值时,就是这个函数的指针。

    10910

    【C语言】C语言 4 个编译过程详解

    C语言的编译过程涉及几个关键步骤、概念和细节,每个步骤都有助于将人类可读的源代码转换为可执行的机器码。以下是详细的解释和示例:一、什么是编译?编译是将源代码转换为目标代码的过程。...示例:后缀:.i (生成的预处理后的源文件)。编译:mov eax, 42概念:编译器 (gcc, clang) 将预处理后的源代码翻译成特定于目标体系结构的汇编语言。...hex 和 .bin 文件通常不是C语言编译过程的直接产物,而是在嵌入式系统开发中常见的文件格式,用于存储程序或数据的二进制表示。...这些文件通常是在程序已经编译、链接并生成了可执行文件之后,通过特定的工具或者转换过程生成的。因此,它们不属于C语言编译过程的标准阶段,但是在嵌入式开发中是非常常见的文件格式。....编译:将C源代码转换为汇编语言。汇编:将汇编指令转换为机器码。链接:将机器码与标准库函数(如 printf)结合,生成最终的可执行文件。

    84510

    c语言 数组存放规则,C语言数组详解

    下标表示了元素在数组中的顺序号。数组元素的一般形式为: 数组名[下标] 其中的下标只能为整型常量或整型表达式。如为小数时,C编译将自动取整。...初始化赋值的一般形式为: static 类型说明符 数组名[常量表达式]={值,值……值}; 其中static表示是静态存储类型, C语言规定只有静态存储数组和外部存储数组才可作初始化赋值(有关静态存储...C语言允许这种分解有二维数组a[3][4],可分解为三个一维数组,其数组名分别为a[0],a[1],a[2]。对这三个一维数组不需另作说明即可使用。...这是由于在C语言中规定,数组名就代表了该数组的首地址。 整个数组是以首地址开头的一块连续的内存单元。如有字符数组char c[10],在内存可表示如图4.2。...设数组c的首地址为2000,也就是说c[0]单元地址为2000。则数组名c就代表这个首地址。因此在c前面不能再加地址运算符&。如写作scanf(“%s”,&c);则是错误的。

    6.3K30

    C语言switch语句的用法详解_c语言switch语句例题

    大家好,又见面了,我是你们的朋友全栈君。 C语言虽然没有限制 if else 能够处理的分支数量,但当分支过多时,用 if else 处理会不太方便,而且容易出现 if else 配对出错的情况。...printf(“Sunday\n”); }else{ printf(“error\n”); } return 0; } 运行结果: Input integer number:3 Wednesday C语言还提供了另外一种多分支选择的语句...需要注意的是,当找到一个相等的 case 分支后,会执行该分支以及之后所有分支的语句。...这显然不是我们想要的结果,我们希望只执行第四个分支,跳过后面的所有分支。 为了避免这种情况,C语言还提供了一个关键字 break,专门用于跳出switch语句。...以上就是对C语言switch语句的资料整理,学习 C语言条件语句的同学可以参考下。

    1.6K30

    【C语言】循环语句详解

    一、while循环 while的语法与if的语法结构类似,下面我们从它们的对比开始学习,if语句: while语句:    可以发现if语句是判断括号中的表达式是否为真,比如上图就是判断...C语⾔中提供了 break 和 continue 两个关键字,就是应⽤到循环中的。 • break 的作⽤是⽤于永久的终⽌循环,只要 break 被执⾏,直接就会跳出循环,继续往后执⾏。...continue 是继续的意思,在循环中的作⽤就是跳过本次循环中 continue 后边的代码,继续进⾏下⼀次循环的判断。...五、循环的嵌套 此处我们举一个例子讲解循环的嵌套    要求:找出100~200之间的素数,并打印在屏幕上。注:素数⼜称质数,只能被1和本⾝整除的数字。...六、goto语句    C语⾔提供了⼀种⾮常特别的语法,就是 goto 语句和跳转标号, goto 语句可以实现在同⼀个函数内跳转到设置好的标号处。

    10910
    领券