注册 登录
编程论坛 C++教室

求助!这是怎么回事?

loookc 发布于 2009-10-16 22:30, 1126 次点击
各位大虾
今天编了一个程序,经过几次修改,终于可以编译生成可执行文件了,但是在运行时又出问题了
出现了“ox00401810”指令引用的“ox33463280”内存。该内存不能为“read”
究竟怎么回事啊?
谢过各位大虾了
谢过所有看帖的人
20 回复
#2
loookc2009-10-16 22:46
我把源码粘出来
#include<iostream>
using std::cin;
using std::cout;
using std::endl;
int main()
{
int bYear[]={31,29,31,30,31,30,31,31,30,31,30,31};
int sYear[]={31,28,31,30,31,30,31,31,30,31,30,31};
cout<<"enter year,month,day:"<<endl;
int year,month,day;
int s1,s2,s,fact;
int i;
s1=(year-1)+((year-1)/4)-((year-1)/400);
cin>>year>>month>>day;
if(year%400&&year%4)
   for(;i<=(month-1);++i)
      {
      cout<<endl;
      s2=s2+bYear[i];
      }
   s2=s2+day;
if(year%400!=0&&year%4!=0)
{
     for(;i<=(month-1);++i)
   {
   s2+=sYear[i];
   }
   s2=s2+day;
}
s=s1+s2;
fact=s%7;
switch(fact)
{
   case 0:
      cout<<"today is sunday";
      break;
   case 1:
      cout<<"today is monday";
      break;
   case 2:
      cout<<"today is tuseday";
      break;
   case 3:
      cout<<"today is wednesday";
      break;
   case 4:
      cout<<"today is thurday";
      break;
   case 5:
      cout<<"today is friday";
      break;
   case 6:
      cout<<"today is saturday";
      break;
   default:cout<<"this program has bugs.";
}
return 0;
}        
 
 
#3
narcissushtl2009-10-16 22:58
第13行:s1=(year-1)+((year-1)/4)-((year-1)/400);  
第14行:cin>>year>>month>>day;  
这两句换一下
#4
loookc2009-10-16 23:07
还是不行啊
#5
flyingcloude2009-10-16 23:37
程序应该是在month>12的时候出错的吧
#6
loookc2009-10-17 07:19
我觉得是数组在调用内存时失败造成的
有这种可能么?
#7
flyingcloude2009-10-17 09:22
回复 6楼 loookc
当你month>12之后,就有可能出现错误了,因为数据已经越界了,month在0到12之间应该不会有错的。
#8
落落的世界2009-10-17 10:57
你好,我刚才看了下,发现程序有些许错误:
 
首先,定义变量时,s2要赋初值,s2=0;
其次,同样i也得赋初值,i=0;
而后,最严重的问题是:
if(year%400&&year%4)  
   for(;i<=(month-1);++i)  
      {  
      cout<<endl;  
      s2=s2+bYear[i];  
      }  
   s2=s2+day;  
该if语句有错误,应该这样写————
if(year%400&&year%4)   
  { for(;i<=(month-1);++i)   
      {   
      cout<<endl;   
      s2=s2+bYear[i];   
      }   
   s2=s2+day;
 }
可以了.....over
#9
最左边那个2009-10-17 11:22
我看了一下,8楼说的对,s2,和i都没有初始值就直接去做加减运算,这样的话,编译软件很可能就会给它一个某个范围内的随机值,这样很可能是问题原因之一!
你这样修改以后,会发现能够比较好的运行可执行文件了,但是又还是有新问题的!
这时候,你应该去检测一下这个fact就会发现,无论你输什么进去,fact都是个负数!所以总是this program has bugs。
#10
东海一鱼2009-10-17 11:50
回复 9楼 最左边那个
cin>>year>>month>>day;
    s1=(year-1)+((year-1)/4)-((year-1)/400);
    if(year%400&&year%4)
        for(i=0;i<=(month-1);++i)
        
声明fact为unsigned int就好,呵呵。
#11
loookc2009-10-17 12:24
经过大家的共同努力,我们成功了!下面的源代码是改好的
它的功能是计算任意一天是星期几
请大家分享
#include<iostream>
using std::cin;
using std::cout;
using std::endl;
int main()
{
int bYear[]={31,29,31,30,31,30,31,31,30,31,30,31};
int sYear[]={31,28,31,30,31,30,31,31,30,31,30,31};
cout<<"enter year,month,day:"<<endl;
int year,month,day;
int s1=0,s2=0,s=0,fact=0;
int i;
cin>>year>>month>>day;
s1=(year-1)+((year-1)/4)-((year-1)/100)+((year-1)/400);
if(year%400||year%4)
{
   for(i=0;i<=(month-1);++i)
      {
      s2=s2+bYear[i];
      }   
}
if(year%400!=0||year%4!=0)
{
     for(i=0;i<=(month-1);++i)
     {
        s2=s2+sYear[i];
     }
}
s2=s2+day;
s=s1+s2;
fact=s%7;
switch(fact)
{
   case 0:
      cout<<"today is sunday\n";
      break;
   case 1:
      cout<<"today is monday\n";
      break;
   case 2:
      cout<<"today is tuseday\n";
      break;
   case 3:
      cout<<"today is wednesday\n";
      break;
   case 4:
      cout<<"today is thurday\n";
      break;
   case 5:
      cout<<"today is friday\n";
      break;
   case 6:
      cout<<"today is saturday\n";
      break;
   default:cout<<"this program has bugs.";
}
return 0;
}      
谢谢大家!!!!!!!!!!!

[ 本帖最后由 loookc 于 2009-10-17 13:16 编辑 ]
#12
最左边那个2009-10-17 13:43
回复 10楼 东海一鱼
可是int fact 的话,会默认为是unsigned int fact吗?
我个人觉得是不会,所以,如果是我,我会做一些处理!
不过只是个人理解,还请你给我解释一下,谢谢!
#13
东海一鱼2009-10-17 14:17
以下是引用最左边那个在2009-10-17 13:43:02的发言:

可是int fact 的话,会默认为是unsigned int fact吗?
我个人觉得是不会,所以,如果是我,我会做一些处理!
不过只是个人理解,还请你给我解释一下,谢谢!
  声明int fact当然不会自动做unsigned int转换。
  所以我说必须将fact声明为unsigned int型才可以。

  或者就像你所说的自己做一些处理。比如说你可以用数学函数abs求绝对值。

  也可以自定义一个宏:
  #define   MYABS(x) ((x)<0?-(x):(x))

  switch(MYABS(fact))
        {
         。。。。。。
         。。。。。。
        }

都可以,你只要明白其中的道理就行。
#14
loookc2009-10-17 14:44
以下是引用东海一鱼在2009-10-17 14:17:51的发言:

  声明int fact当然不会自动做unsigned int转换。
  所以我说必须将fact声明为unsigned int型才可以。

  或者就像你所说的自己做一些处理。比如说你可以用数学函数abs求绝对值。

  也可以自定义一个宏:
  #define ...
应该不用
因为根据算“任意一天是星期几的算法看来”fact是不会为负的
#15
loookc2009-10-17 15:05
经过测试,上面的程序有误
#16
loookc2009-10-17 15:25
改了的
#include<iostream>
using std::cin;
using std::cout;
using std::endl;
int main()
{
int bYear[]={31,29,31,30,31,30,31,31,30,31,30,31};
int sYear[]={31,28,31,30,31,30,31,31,30,31,30,31};
cout<<"enter year,month,day:"<<endl;
int year,month,day;
int s1=0,s2=0,s=0,fact=0;
int i;
cin>>year>>month>>day;
s1=(year-1)+((year-1)/4)-((year-1)/100)+((year-1)/400);
     if((year%4==0)&&(year%100!=0)||(year%400==0))
     {
         for(i=0;i<=(month-2);++i)
         {
         s2=s2+bYear[i];
         }   
     }
     else
     {  
         for(i=0;i<=(month-2);++i)
         {
         s2=s2+sYear[i];
         }
     }
      
s2=s2+day;
s=s1+s2;
fact=s%7;
switch(fact)
{
   case 0:
      cout<<"this day is sunday\n";
      break;
   case 1:
      cout<<"this day is monday\n";
      break;
   case 2:
      cout<<"this day is tuseday\n";
      break;
   case 3:
      cout<<"this day is wednesday\n";
      break;
   case 4:
      cout<<"this day is thurday\n";
      break;
   case 5:
      cout<<"this day is friday\n";
      break;
   case 6:
      cout<<"this day is saturday\n";
      break;
   default:cout<<"this program has bugs.";
}
return 0;
}      
#17
wghost2009-10-17 15:27
8楼说的对,下面是我做的一些修改
#include<iostream>  
using namespace std;                                   //c++中开头用此两行就可以
int main()  
{  
int bYear[]={0,31,29,31,30,31,30,31,31,30,31,30,31};  //如果要是i=0必须这样定义
int sYear[]={0,31,28,31,30,31,30,31,31,30,31,30,31};  
cout<<"enter year,month,day:"<<endl;  
int year,month,day;  
int s1,s2,s,fact;  
int i;  
s2=0;
cin>>year>>month>>day;  
s1=(year-1)+((year-1)/4)-((year-1)/400);               //将两行调换,否则出想你说的错误
if(year%400&&year%4)  
{for(i=0;i<=(month-1);++i)  
      {  
      cout<<endl;  
      s2=s2+bYear[i];  
      }  
  s2=s2+day;}  
if(year%400!=0&&year%4!=0)  
{  
     for(i=0;i<=(month-1);++i)  
   {  
   s2+=sYear[i];  
   }  
   s2=s2+day;  
}  
s=s1+s2;  
fact=s%7;  
switch(fact)  
{  
   case 0:  
      cout<<"today is sunday";  
      break;  
   case 1:  
      cout<<"today is monday";  
      break;  
   case 2:  
      cout<<"today is tuseday";  
      break;  
   case 3:  
      cout<<"today is wednesday";  
      break;  
   case 4:  
      cout<<"today is thurday";  
      break;  
   case 5:  
      cout<<"today is friday";  
      break;  
   case 6:  
      cout<<"today is saturday";  
      break;  
   default:cout<<"this program has bugs.";  
}  
return 0;  
}         
#18
w2737325732009-10-17 19:27
你利用的是哪个公式呀?
你那边润年,非润年的好像很有问题。。。非常有问题
#19
w2737325732009-10-17 19:49
#include<iostream>  
using std::cin;  
using std::cout;  
using std::endl;  
int main()  
{  
int bYear[]={31,29,31,30,31,30,31,31,30,31,30,31};  
int sYear[]={31,28,31,30,31,30,31,31,30,31,30,31};  
cout<<"enter year,month,day:"<<endl;  
int year,month,day;  
int s1,s2=0,s,fact;  
int i;  
cin>>year>>month>>day;  
s1=(year-1)+(year-1)/4-((year-1)/100)+((year-1)/400);  //这年份的公式写错。。
 
if(year%400==0||(year%100!=0&&year%4==0))  //润年的判断出错。。
{
   for(i=0;i<(month-1);++i)  //月份不要等号, 等号下去就相当于多加了一月的天数。。。还有i最好也初始化下。。。
      {  
      cout<<endl;  
      s2=s2+bYear[i];  
      }  
   s2=s2+day;  
}
else
{  
     for(i=0;i<(month-1);++i)  
   {  
   s2+=sYear[i];  
   }  
   s2=s2+day;  
}  
s=s1+s2;  
fact=s%7;  
switch(fact)  
{  
   case 0:  
      cout<<"today is sunday";  
      break;  
   case 1:  
      cout<<"today is monday";  
      break;  
   case 2:  
      cout<<"today is tuseday";  
      break;  
   case 3:  
      cout<<"today is wednesday";  
      break;  
   case 4:  
      cout<<"today is thursday";  
      break;  
   case 5:  
      cout<<"today is friday";  
      break;  
   case 6:  
      cout<<"today is saturday";  
      break;  
   default:cout<<"this program has bugs.";  
}  
cout<<endl;
return 0;  
}         
#20
loookc2009-10-17 22:21
#include<iostream>
using std::cin;
using std::cout;
using std::endl;
int main()
{
int bYear[]={31,29,31,30,31,30,31,31,30,31,30,31};
int sYear[]={31,28,31,30,31,30,31,31,30,31,30,31};
cout<<"enter year,month,day:"<<endl;
int year,month,day;
int s1=0,s2=0,s=0,fact=0;
int i;
cin>>year>>month>>day;
s1=(year-1)+((year-1)/4)-((year-1)/100)+((year-1)/400);
     if((year%4==0)&&(year%100!=0)||(year%400==0))
     {
         for(i=0;i<=(month-2);++i)
         {
         s2=s2+bYear[i];
         }   
     }
     else
     {  
         for(i=0;i<=(month-2);++i)
         {
         s2=s2+sYear[i];
         }
     }
      
s2=s2+day;
s=s1+s2;
fact=s%7;
switch(fact)
{
   case 0:
      cout<<"this day is sunday\n";
      break;
   case 1:
      cout<<"this day is monday\n";
      break;
   case 2:
      cout<<"this day is tuseday\n";
      break;
   case 3:
      cout<<"this day is wednesday\n";
      break;
   case 4:
      cout<<"this day is thurday\n";
      break;
   case 5:
      cout<<"this day is friday\n";
      break;
   case 6:
      cout<<"this day is saturday\n";
      break;
   default:cout<<"this program has bugs.";
}
return 0;
}      
大家再看看
#21
caolihui10082009-10-19 09:27
怎么没给year month等初始化就直接减呢?
楼上的应该是对的
1