C语言新手写函数中出现数组时运行bug的解决

一.发现问题:

这是我今天写代码的一小部分,是创建一个数组,然后函数init()是初始化数组,代码如下:

cpp 复制代码
void init(int arr[10],unsigned int k) {
	int i = 0;
	for (i = 0; i < k; i++) {
		arr[i] = 0;
	}
}
int main() {
	int arr[10] = { 1 };

	init(arr[10], sizeof (arr) / sizeof(arr[0]));
}

有这样一个简单的代码,但是在运行的时候,出现了运行bug,是这样显示的:

0x00007FF6975F18E1 处(位于 C_2.18.exe 中)引发的异常: 0xC0000005: 写入位置 0xFFFFFFFFCCCCCCCC 时发生访问冲突。

究竟是为什么呢?

二.bug引发原因

这个错误信息表明在程序执行过程中发生了访问冲突,具体来说是写入了一个无效的内存地址。0xC0000005是Windows操作系统中的一种常见错误代码,表示访问违例(Access Violation)。

实际上的意思就是,我们在函数传参的时候出现了传参错误,导致访问出现了错误,一般来说,我们应该确保指针和数组的使用是合法的,并避免写入无效的内存地址。

三.解决方法

实际上,我们init()函数需要传入的参数是数组arr,以及数组的长度,但是在主函数的里面,我们引用init函数,仅仅是传入了arr[10]一个元素,而不是传入了一个数组,因此,我们在传参时候一定要注意不要出错,保证类型是相同的。

我们更该代码为:

cpp 复制代码
void init(int arr[10],unsigned int k) {
	int i = 0;
	for (i = 0; i < k; i++) {
		arr[i] = 0;
	}
}
int main() {
	int arr[10] = { 1 };

	init(arr, sizeof (arr) / sizeof(arr[0]));
}

这样,就可以正常运行了。

相关推荐
BanyeBirth16 分钟前
C++高精度算法(加、减、乘)
开发语言·c++·算法
houliabc16 分钟前
C语言个人笔记
c语言·数据结构·笔记·算法
Allen Wurlitzer36 分钟前
算法刷题记录——LeetCode篇(1.9) [第81~90题](持续更新)
算法·leetcode·职场和发展
@MrLiu37 分钟前
# 深度学习中的优化算法详解
人工智能·深度学习·算法·优化器
阳洞洞40 分钟前
leetcode 377. Combination Sum IV
算法·leetcode·动态规划·完全背包问题
·云扬·43 分钟前
【BUG】远程连接阿里云服务器上的redis报错
服务器·阿里云·bug
双叶8361 小时前
(51单片机)串口通讯(串口通讯教程)(串口接收发送教程)
c语言·开发语言·c++·单片机·嵌入式硬件·microsoft·51单片机
阿巴~阿巴~1 小时前
蓝桥杯 C/C++ 组历届真题合集速刷(一)
c语言·c++·算法·蓝桥杯
_x_w1 小时前
【12】数据结构之基于线性表的排序算法
开发语言·数据结构·笔记·python·算法·链表·排序算法
瀚海澜生2 小时前
链表系列入门指南(二):吃透这几题,链表解题不再难
后端·算法