博客
关于我
2021年4月18日C语言Vc6输出结果出现-858993460
阅读量:396 次
发布时间:2019-03-05

本文共 1093 字,大约阅读时间需要 3 分钟。

数组初始化错误与循环条件失控

在编写C语言程序时,经常会遇到一些容易导致逻辑错误的问题。本文将详细分析一个常见的数组索引错误案例,并说明如何通过合理的代码修正来避免问题。

数组访问错误分析

以下代码段中,用户尝试读取并打印一个数组的元素:

#include 
int main() { int a[100], i = 0, m, n = 3; char ch; printf("请输入你想要的升序排列的数字,按回车键结束\n"); do { scanf("%d", &a[i]); i++; } while (ch = getchar() != '\n'); for (m = 0; m <= i; m++) { printf("%3d\n", a[m]); }}

在上述代码中,for循环的条件设置为m <= i,这意味着当i达到预期值时,m会继续执行循环体内的代码。这种情况下,会多打印一个未初始化的数组元素。

错误原因

数组在C语言中是以零索引的方式存储的。i变量在循环中被初始化为0,并且一直增加直到用户输入结束。for循环的条件m <= i实际上会比预期多运行一次。例如,当i在最后一次循环中达到99时,m也会继续执行到100次循环,导致a[100]被访问,这在数组a的定义中是未被初始化的内存位置。

这样一来,程序会输出一个未经赋值的未知值(通常为-858993460),这正是用户所遇到的问题。

代码修正方法

为了修正这个错误,我们只需要将for循环的条件从m <= i更改为m < i。这样,循环将正好执行i次,避免多打印一个未初始化的元素。

修正后的代码如下:

#include 
int main() { int a[100], i = 0, m, n = 3; char ch; printf("请输入你想要的升序排列的数字,按回车键结束\n"); do { scanf("%d", &a[i]); i++; } while (ch = getchar() != '\n'); for (m = 0; m < i; m++) { printf("%3d\n", a[m]); }}

总结

数组索引错误是一个常见的问题,尤其是在使用零索引系统时。通过仔细检查循环条件,可以有效避免类似的错误。记住,在编写循环时,始终明确循环的起始和结束条件,以避免程序运行异常。

转载地址:http://gkeg.baihongyu.com/

你可能感兴趣的文章
NHibernate异常:No persister for的解决办法
查看>>
NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
查看>>
NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
查看>>
NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
查看>>
NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
查看>>
Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
查看>>
NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
查看>>
NIFI大数据进阶_NIFI的模板和组的使用-介绍和实际操作_创建组_嵌套组_模板创建下载_导入---大数据之Nifi工作笔记0022
查看>>
NIFI大数据进阶_NIFI监控的强大功能介绍_处理器面板_进程组面板_summary监控_data_provenance事件源---大数据之Nifi工作笔记0025
查看>>
NIFI大数据进阶_内嵌ZK模式集群1_搭建过程说明---大数据之Nifi工作笔记0015
查看>>
NIFI大数据进阶_外部ZK模式集群1_实际操作搭建NIFI外部ZK模式集群---大数据之Nifi工作笔记0017
查看>>
NIFI大数据进阶_离线同步MySql数据到HDFS_01_实际操作---大数据之Nifi工作笔记0029
查看>>
NIFI大数据进阶_离线同步MySql数据到HDFS_02_实际操作_splitjson处理器_puthdfs处理器_querydatabasetable处理器---大数据之Nifi工作笔记0030
查看>>
NIFI大数据进阶_连接与关系_设置数据流负载均衡_设置背压_设置展现弯曲_介绍以及实际操作---大数据之Nifi工作笔记0027
查看>>
NIFI数据库同步_多表_特定表同时同步_实际操作_MySqlToMysql_可推广到其他数据库_Postgresql_Hbase_SqlServer等----大数据之Nifi工作笔记0053
查看>>