首页 > 代码库 > 编译器实践 二 之 小型的词法分析器
编译器实践 二 之 小型的词法分析器
以下是一个简单的词法分析器
#include <stdio.h> #include <string.h> using namespace std ; int main() { char str[150] ; // freopen("C:\\Users\\Lionel\\Desktop\\1.txt","r",stdin) ; int row = 1 , cow = 0 ; while(gets(str)) { char temp[10] ; int index = 0 , i = 0; while(i<strlen(str)+1) { if(str[i] == ‘ ‘ || str[i] == ‘\t‘ || str[i] == ‘\0‘) { temp[index] = ‘\0‘ ; if(!strcmp(temp,"if")) { printf("IF (%d,%d)\n",row,i-index+1) ; } else { bool flag = false ; for(int j = 0 ; j < index ; ++j) { if(temp[j]<‘0‘ || temp[j]>‘9‘) { flag = true ; break ; } } if(flag) { printf("ID(%s) (%d,%d)\n",temp,row,i-index+1) ; } else { printf("NUM(%s) (%d,%d)\n",temp,row,i-index+1) ; } } while((str[i] == ‘ ‘ || str[i] == ‘\t‘) && (str[i+1] == ‘ ‘ || str[i+1] == ‘\t‘)) { ++i ; } index = 0 ; } else { temp[index++] = str[i] ; } ++i ; } row++ ; } return 0 ; }
与君共勉
编译器实践 二 之 小型的词法分析器
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。