本文共 2993 字,大约阅读时间需要 9 分钟。
输入程序的目标是将源文件中C风格的注释转换为C++风格的注释,并将结果保存到另一个文件中。通过对原有注释的识别和处理,程序能够按照目标语言的注释风格进行转换。
#include#pragma warning(disable:4996)typedef enum Condition { NOT_ANNOTATION, MAYBE_IN_ANNOTATION, C_ANNOTATION, CPP_ANNOTATION, MAYBE_OUT_ANNOTATION} Condition;int main() { FILE *pIn = fopen("input.c", "rt"); if (pIn == NULL) { perror("fopen test"); return 1; } FILE *pOut = fopen("output.c", "wt"); if (pOut == NULL) { fclose(pIn); perror("fopen out"); return 1; } char ch; Condition state = NOT_ANNOTATION; do { ch = fgetc(pIn); switch (state) { case NOT_ANNOTATION: if (ch == '/') { state = MAYBE_IN_ANNOTATION; fputc(ch, pOut); } else { state = NOT_ANNOTATION; fputc(ch, pOut); } break; case MAYBE_IN_ANNOTATION: if (ch == '/') { state = CPP_ANNOTATION; fputc(ch, pOut); } else if (ch == '*') { state = C_ANNOTATION; fputc('/', pOut); } else { state = NOT_ANNOTATION; fputc(ch, pOut); } break; case CPP_ANNOTATION: if (ch == '\n') { state = NOT_ANNOTATION; fputc(ch, pOut); } else { fputc(ch, pOut); } break; case C_ANNOTATION: if (ch == '*') { state = MAYBE_OUT_ANNOTATION; } else { fputc(ch, pOut); if (ch == '\n') { fprintf(pOut, "//"); } } break; case MAYBE_OUT_ANNOTATION: if (ch == '*') { fputc('*', pOut); state = MAYBE_OUT_ANNOTATION; } else if (ch == '/') { char nextch = fgetc(pIn); if (nextch != '\n') { fputc('\n', pOut); } ungetc(nextch, pIn); state = NOT_ANNOTATION; } else { fputc('*', pOut); fputc(ch, pOut); state = C_ANNOTATION; } break; } } while (ch != EOF); fclose(pOut); fclose(pIn); return 0;}
状态枚举:定义了五种状态,分别为未注释(NOT_ANNOTATION
)、可能进入注释(MAYBE_IN_ANNOTATION
)、C风格注释(C_ANNOTATION
)、C++风格注释(CPP_ANNOTATION
)以及可能出注释(MAYBE_OUT_ANNOTATION
)。
读取和处理字符:
NOT_ANNOTATION
时,若字符为/
,则可能进入注释模式;否则保持非注释状态。MAYBE_IN_ANNOTATION
状态下,遇到/
转为C++注释模式,遇到*
转为C风格注释模式。\n
转换回非注释状态。*
进入可能出注释状态,正常字符则输出*
并显示字符。/
则检查下一个字符是否为\n
,决定是否插入换行符。输出处理:
该程序逻辑清晰,能够准确识别和转换不同注释类型,同时兼容C和C++的注释风格。
转载地址:http://oblkk.baihongyu.com/