| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 844 人关注过本帖
标题:关于数组的讨论
只看楼主 加入收藏
coachard
Rank: 3Rank: 3
等 级:新手上路
威 望:7
帖 子:1251
专家分:0
注 册:2007-8-12
收藏
得分:0 
太粗心了,搞不好整个程序就因为这个小地方崩溃了

偶学编程,也许本身就是一个错。。。
2007-08-13 18:46
寻乐的狼
Rank: 1
等 级:新手上路
帖 子:118
专家分:0
注 册:2007-2-16
收藏
得分:0 
谢谢大家热心的回答

9楼:如果COUNT〈[]中数,会怎样

10楼:也就是在存储数据和读取数据不一样?
如果是在引用时,又会怎样


用C打破禁锢的世界
2007-08-13 22:59
leeco
Rank: 4
等 级:贵宾
威 望:10
帖 子:1029
专家分:177
注 册:2007-5-10
收藏
得分:0 
以下是引用寻乐的狼在2007-8-13 22:59:22的发言:
谢谢大家热心的回答

9楼:如果COUNT〈[]中数,会怎样

10楼:也就是在存储数据和读取数据不一样?
如果是在引用时,又会怎样

在定义的时候,如果我用int arr[4]={1,1,1};我定义了4的大小,但是只赋值3个,这时候后面两个会被负默认值0,也就是a[3]==0成立
如果我定义的时候用int arr[]={1,1,1};等价与int arr[3]={1,1,1},这时候后面的空间并没有分配给arr,arr[3]的值是不确定的

2007-08-13 23:22
寻乐的狼
Rank: 1
等 级:新手上路
帖 子:118
专家分:0
注 册:2007-2-16
收藏
得分:0 
以下是引用leeco在2007-8-13 23:22:08的发言:

在定义的时候,如果我用int arr[4]={1,1,1};我定义了4的大小,但是只赋值3个,这时候后面两个会被负默认值0,也就是a[3]==0成立
如果我定义的时候用int arr[]={1,1,1};等价与int arr[3]={1,1,1},这时候后面的空间并没有分配给arr,arr[3]的值是不确定的



那如果int arr[1]={1,2,3)那这样会产生错误?
如果在读取数据时,这两种又是什么结果呢

用C打破禁锢的世界
2007-08-13 23:52
leeco
Rank: 4
等 级:贵宾
威 望:10
帖 子:1029
专家分:177
注 册:2007-5-10
收藏
得分:0 
以下是引用寻乐的狼在2007-8-13 23:52:24的发言:
那如果int arr[1]={1,2,3)那这样会产生错误?
如果在读取数据时,这两种又是什么结果呢

int arr[1]={1,2,3};通不过编译,你可以自己试嘛。读取数据是什么结果我已经说了

2007-08-14 01:30
chen7806
Rank: 1
等 级:新手上路
威 望:2
帖 子:160
专家分:0
注 册:2007-8-5
收藏
得分:0 
以下是引用寻乐的狼在2007-8-13 9:35:31的发言:

/* 晕,忘说了,运行环境 Dev—C++4.9.9.2,英文原版,官网下的。*/
#include<stdio.h>

int count,total1,total2,total;

int array1[]={1,1,1,1,1},array2[]={3,3,3,3,3,7};/* 他的运行结果为何是30,多了3的一倍 ;把count<7,(3,3,3,3,3,7,8)结果为41,多了3的两倍;把count 给成8,(3,3,3,3,3,7,8,9)这又是正确的了*/

int main(void)
{
for(count=0;count<6;count++)
{
total1+=array1[count];
total2+=array2[count];
}
printf("%d",total1+total2);
system("PAUSE");
return 0;
}


数组越界,C语言是不会提醒的,仍能执行,不过会产生垃圾数据。
你的计算结果是拉圾数据造成的。array1[]元素与for()不匹配。

2007-08-14 09:27
快速回复:关于数组的讨论
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.027849 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved