C语言-指针变量,常量与数组名的细微区别辨析

本节根据两个选择题进行展开辨析

一、例1

本题答案:C

解析:强干扰选项是B,我相信大多数同学都会在B,C之间犹豫好久,那么为什么答案会最终选择C呢?因为本题在定义函数所以a首先是一个数组名,其次是一个指针常量,那为什么不是指针变量呢,这要分情况,我们不能简单的认为double a[];这种形式的写法a都是指针变量,如果是在定义函数时,那么函数形参处的double a[]写法,a是指针常量 ,举个例子:

例子代码:

cpp 复制代码
#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
int main()
{
	//首先要明确数组名本质是一个地址,这个地址可能是指针常量,也有可能是指针变量
	float a[10] = { 0 };//a此时为指针常量
	void fun1(float arr1[]);//形参arr1此时为指针变量
	void fun2(float* arr2);//形参arr2此时为指针变量
	fun1(a); //a 作为指针常量被传递,相当于传入的是数组的首地址
	fun2(a); //a 作为指针常量被传递,相当于传入的是数组的首地址
	return 0;
}
void fun1(float arr1[])//arr1此时为指针常量
{
	
}
void fun2(float* arr2)//arr2此时为指针常量
{

}

二、例2(如果例1)能够理解,可以尝试一下该题

本题答案:A

补充说明:函数声明意味着float array[]在赋值的位置,相当于在赋值运算符的右侧

三、总结

如何区分float array[]这种类型写法array是指针变量还是指针常量呢?☆☆☆☆☆

看float array[]出现的位置,如果float array[]出现的位置是被赋值的位置,即相当于赋值运算符左侧,那么array一定是指针常量,相反,如果float array[]出现的位置是赋值的位置,即相当于在赋值运算符的右侧,那么array一定是指针变量!可以用上述两例题进行验证。

相关推荐
秦苒&7 分钟前
【C语言指针二】从入门到通透:核心知识点全梳理(野指针,assert断言,指针的使用和传址调用,数组名的理解和使用指针反访问数组)
c语言·开发语言
Tandy12356_1 小时前
手写TCP/IP协议——IP层输出处理
c语言·网络·c++·tcp/ip·计算机网络
Y1rong4 小时前
C++ QT之记事本
开发语言·qt
diegoXie8 小时前
Python / R 向量顺序分割与跨步分割
开发语言·python·r语言
程序员小白条8 小时前
0经验如何找实习?
java·开发语言·数据结构·数据库·链表
liulilittle8 小时前
C++ 浮点数封装。
linux·服务器·开发语言·前端·网络·数据库·c++
失散139 小时前
Python——1 概述
开发语言·python
萧鼎9 小时前
Python 图像哈希库 imagehash——从原理到实践
开发语言·python·哈希算法
小小8程序员9 小时前
STL 库(C++ Standard Template Library)全面介绍
java·开发语言·c++
立志成为大牛的小牛9 小时前
数据结构——五十六、排序的基本概念(王道408)
开发语言·数据结构·程序人生·算法