问题描述:
在CodeBlocks等IDE中都提供了代码格式整理的功能。完成这种功能的程序,操作的数据是用C++写的源代码文件。C++源文件是一种文本文件,可以通过程序进行操作。
集成开发环境(IDE)对对程序进行编译,操作的“数据”是源程序。编译中,要对源程序进行词法检查和语法检查,后续还要进行目标代码生成、代码优化等工作。相关的技术将在《编译原理》课中学习。这些技术可以用在很多领域,当然也能够让我们对于编程语言有更深的了解。本项目将以C++源程序为操作对象,完成对源程序的一系列处理。各功能可以分别编制一个程序实现(建议用这种简单的方案),也可以将其集成在一起(向着自己做出IDE努力)。
(1)读入一个C++程序,判断其中是否只有一个main()函数,输出“暂时没有发现问题”,或者“没有main()函数”,或者“不能定义多个main()函数”;
提示1:简单处理,可以只比较判断”main()”,考虑实际上的各种可能,main后面的括号中有任意多个空格及void的都应该算在内。建议按最简单的情形处理。
提示2:建议设计一个函数,将读到的代码与字符串”main()”进行比较。函数用于判断s1是否“包含”在读入的一行s2中,调用时,形参s1处的实参用”main()”即可,这样写提升了“抽象”级别,更容易实现,对应更高的代码质量。
代码:
#include <iostream>
#include <cstdio>
#include <cstring>
#include <fstream>
#include <cstdlib>
#include <cctype>
using namespace std;
string s="main()";
string f(string str)
{
string return_str="";
int length=str.length();
for(int i=0;i<length;i++)
if(str[i]!=' ')return_str+=str[i];
return return_str;
}
int fun(string t){
int c;
int i=0,len=t.length(),j;
for(i=0;i<len;++i){
string k;
k+=t[i];k+=t[i+1];k+=t[i+2];k+=t[i+3];k+=t[i+4];k+=t[i+5];k+=t[i+6];
for(j=0,c=1;j<7;j++){
if(k[j]!=s[j]){
c=0;
break;
}
}
if(c)
return 1;
}
return 0;
}
int main(){
string t;
int num=0,i;
fstream myfile("source.cpp",ios::in);
if(!myfile){
cerr<<"can't find sorce.cpp\n";
exit(1);
}
while(!myfile.eof()){
getline(myfile,t);
t=f(t);//删除空格
num+=fun(t);//判断是否有main()
if(num>1)break;
}
if(num==1)printf("source.cpp is legal\n");
else printf("source.cpp is illegal\n");
return 0;
}
运行结果:
大半夜终于搞定了!