前几天写了一个核酸检测的程序,在编写过程中发现了反复在犯几种常见的错误,特此总结一下,以提高后期的纠错速度。
本文使用的编译器是codeblocks
括号丢失这种情况,在你写小程序的时候,根本不能算是问题,但当代码的规模达到一定程度的时候,你就会有应接不暇的感觉了。
Date(int a,int b,int c{year=a;month=b;day=c;}
希望能在大括号 { 前面有一个小括号 )
int gety(){return yea;}
前面定义的是year,后面打错成了yea
void operation::find_name(string string1)
{vector::iterator u=person.begin();
while(u!=person.end())
{
if((*u).getname()==string1)
{ cout<
ostream&operato <<(ostream&output,message&s)
{
output<
<<前面没有initializer,也就是没有按照固定的格式进行编写。
void operation::change_message(string idnum1,int time1,string recent_time1,int outcoming1)
{ map::iterator w=idmap.begin();
while(w!=idmap.end())
{if(idnum1==person[w->second].getidnum() )
{person[idmap[idnum1]].set(time1);
person[idmap[idnum1]].setrecent_time(recent_time1);
person[idmap[idnum1]].setoutcoming(outcoming1);
cout<second].getidnum()&&w!=idmap.end())
{w++;}
if(w==idmap.end())
{cout<<"未找到该成员"<
前面没有set函数,应该写的是setime函数,这是一般会出现__gnu_cxx::_alloc等情况
void operation::find_surname(string a)
{
vector::iterator e=person.begin();
while(1)
{if(a==(e).getname().substr(0,2)&&e!=person.end())
{cout<<"查找到一名姓"<
此处仔细观察可以知道,第五行代码应该是a==(*e),但是没有加上*,导致没法取内容。
在编写程序的时候,特别是规模较为宏大的程序时,一定要注意写程序的技巧
比如说,一个小型的工程项目,要实现很多功能,有生成名单,按各种信息进行查找,等等。
这时,切记不要一门子写完,然后再运行,否则你就会发现,一运行一堆错误,代码还是好几百甚至上千行,严重干扰你的纠错速度,你应该将该功能所需要的成员信息连同这个小的功能函数,重新新建一个文件进行编译,原来我不注意这一点,现在才发现这样做的重要性和高效性。最后,再讲许许多多的小的没有错误的模块拼接在一起,就可以立即组装成一个大的产品了。
在适当的位置添加cout语句可以让你在短时间内定位该范围内是否出现了程序的运行错误。举个例子:
void operation::count_num(int a)
{vector::iterator k=person.begin();
int count=0;
while(k!=person.end())
{if((*k).gettime()==a)
{count++;k++;}
else
k++;
}
这是一个统计人数的函数,我们可以在函数体一开始的时候,添加语句“cout<<1;”
那么函数调用或是函数本身是否存在问题呢,程序运行完成后:
假如你发现没有数字1的输出,那么你就可以迅速定位,错误出现在该行或者是该行以前的位置。
假如你发现有数字1的输出,那么你可以断定该处没有错误,函数可以运行,错误应该存在于该行以后的位置。你应当在后面的代码中选取合适的位置添加cout<<1;比如上述例子,我就会在while语句中添加输出语句,进而判断循环是否出问题。
经过这样的往复判断,你就可以不停地将错误可能存在的范围缩小,最终定位到错误所在行,再结合前面的报错总结进行迅速纠错,如此一来就形成了一个完整的调试程序的闭环。