首页 > 代码库 > 词法分析实战
词法分析实战
题目:
在这部分中,你将使用图转移算法手工实现一个小型的词法分析器。
* 分析器的输入:存储在文本文件中的字符序列,字符取自ASCII字符集。文件中可能包括四种记号:关键字if、符合C语言标准的标识符、空格符、回车符\n。
* 分析器的输出:打印出所识别的标识符的种类、及行号、列号信息。
根据题目的要求,定义如下的Token类:
enum TokenType{
TT_ID,
TT_IF
};
class Token {
public:
Token(){}
Token(TokenType _t, string _n, int _l, int _c) { mType = _t; mName = _n; mLine = _l; mColumn = _c; }
~Token(){}
string toString();
TokenType mType;
string mName;
int mLine;
int mColumn;
};
重点实现获取Token的方法:
Token* nextToken(string& input){
if (input.empty()) {
return NULL;
}
string name;
int i = 0;
if (input[i] == ‘ ‘) {
input = input.substr(1);
gColumn += 1;
return nextToken(input);
}
else if (input[i] == ‘\n‘) {
input = input.substr(1);
gLine += 1;
gColumn = 1;
return nextToken(input);
}
else if (input[i] == ‘i‘) {
i++;
name.append("i");
if (input[i] == ‘f‘) {
i++;
name.append("f");
while ((input[i] >= ‘a‘ && input[i] <= ‘z‘) ||
(input[i] >= ‘A‘ && input[i] <= ‘Z‘) ||
(input[i] >= ‘0‘ && input[i] <= ‘9‘) || input[i] == ‘_‘) {
name.append(input.substr(i, 1));
i++;
}
if (name.compare("if") == 0) {
input = input.substr(i);
Token *token = new Token(TT_IF, "", gLine, gColumn);
gColumn += i;
return token;
}
else {
input = input.substr(i);
Token *token = new Token(TT_ID, name, gLine, gColumn);
gColumn += i;
return token;
}
}
else {
while ((input[i] >= ‘a‘ && input[i] <= ‘z‘) ||
(input[i] >= ‘A‘ && input[i] <= ‘Z‘) ||
(input[i] >= ‘0‘ && input[i] <= ‘9‘) || input[i] == ‘_‘) {
name.append(input.substr(i, 1));
i++;
}
input = input.substr(i);
Token *token = new Token(TT_ID, name, gLine, gColumn);
gColumn += i;
return token;
}
}
else if ((input[i] >= ‘a‘ && input[i] <= ‘z‘) ||
(input[i] >= ‘A‘ && input[i] <= ‘Z‘) || input[i] == ‘_‘) {
i++;
name.append(input.substr(0, 1));
while ((input[i] >= ‘a‘ && input[i] <= ‘z‘) ||
(input[i] >= ‘A‘ && input[i] <= ‘Z‘) ||
(input[i] >= ‘0‘ && input[i] <= ‘9‘) || input[i] == ‘_‘) {
name.append(input.substr(i, 1));
i++;
}
input = input.substr(i);
Token *token = new Token(TT_ID, name, gLine, gColumn);
gColumn += i;
return token;
}
else {
input = input.substr(1);
gColumn += 1;
return nextToken(input);
}
}
代码比较挫,不多说了,感兴趣的自己看吧。
词法分析实战
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。