有时候一个程序中如果注释太多,也会带来很多的不方便,于是便产生了删除注释的需要,删除注释有很多种方法,不过最近实现的用确定有限自动机(DFA)实现起来感觉也是比较方便的。
经过分析需要删除的注释大概有一下4中情况:
1、int a ; //这里是注释 ;
2、int a ; /*这里
是注释
是的*/ ;
3、int a ; /*这里是注释*/ ;
4、对于字符串中的注释符不做处理如:
printf("adfadsf/*sdfaf*/ \n"); 对其中的/**/之间的注释不做处理
printf("adfasdf//adsfadsf//afdadsf\n");对其中的//注释也不做处理
5、对于换行符 \ 不做处理;
6、要求对于其中出现的空行要能够删除(这个我只实现了对于开头没有空格空行的删除,还需要改进的地方)
更具以上要求,对状态进行分析,得出以下的装态转换矩阵:
以下是对于这个的C语言代码实现(From是要删除注释的C文件名,To是删除后的文件名