当前位置: 首页> 游戏> 游戏 > 东莞软件开发企业_中企动力科技股份有限公司成都分公司_营业推广的方式有哪些_南京高端品牌网站建设

东莞软件开发企业_中企动力科技股份有限公司成都分公司_营业推广的方式有哪些_南京高端品牌网站建设

时间:2025/7/14 1:04:58来源:https://blog.csdn.net/weixin_74850661/article/details/147170536 浏览次数:0次
东莞软件开发企业_中企动力科技股份有限公司成都分公司_营业推广的方式有哪些_南京高端品牌网站建设

文章目录

  • 实验环境的准备
  • 实验
    • 实验预备知识
    • 分析案例
    • 所要做的任务
    • 实战

实验环境的准备

  • 安装flex
    在这里插入图片描述

  • 安装MinGW
    在这里插入图片描述

  • MinGW Installation Manager页面

在这里插入图片描述

  • apply changes

在这里插入图片描述

下载比较耗时

在这里插入图片描述

  • 只看到了一个文件,复制过去

在这里插入图片描述

  • 配置环境变量

在这里插入图片描述

  • 使用gcc -v检验是否安装完成

在这里插入图片描述

实验

实验预备知识

  • 咱们先来分析一下实验到底想让我们干什么!

flex是干什么的

  • flex(Fast Lexical Analyzer Generator)是一个词法分析器生成工具,用于自动生成词法分析器(lexer/scanner)的代码

  • 输入:flex 接收一个 .l(或 .lex)文件,其中定义了词法规则(正则表达式 + 动作)。

  • 输出:生成一个 C 语言 的词法分析器(通常是 lex.yy.c),该代码可以识别输入流中的单词(token)。

  • 用途:主要用于编译器、解释器、文本处理工具等需要分词(tokenization)的场景。

flex 的基本工作原理
# flex 的工作流程:
(1)编写 .l 文件:定义词法规则(正则表达式 + 对应的动作)。
(2)运行 flex:生成 lex.yy.c(词法分析器代码)。
(3)编译 lex.yy.c:生成可执行程序,用于分词。

典型的.l文件

%{
/* C 代码,如头文件、变量声明 */
#include <stdio.h>
%}/* 正则表达式定义 */
DIGIT    [0-9]
LETTER   [a-zA-Z]%%
/* 规则部分:模式 + 动作 */
{DIGIT}+    { printf("Number: %s\n", yytext); }
{LETTER}+   { printf("Word: %s\n", yytext); }
[ \t\n]     ;  /* 忽略空白符 */
.           { printf("Unknown: %s\n", yytext); }
%%/* 可选的 C 代码(如 main 函数) */
int main() {yylex();  // 启动词法分析return 0;
}

分析案例

  • 实验名称:识别输入文本中的单词(word)和数(num)并分别统计个数

实例.lex代码

%{
/* 全局变量声明部分(C代码块) */
int wordCount = 0;   // 统计单词数量
int numCount = 0;    // 统计数字数量
%}/* 正则表达式定义部分 */
chars      [A-Za-z\_\'\.\"]    // 匹配字母、下划线、引号等字符
numbers    ([0-9])+           // 匹配一个或多个数字
delim      [" "\n\t]          // 匹配空格、换行、制表符等分隔符
whitespace {delim}+           // 匹配一个或多个分隔符
words      {chars}+           // 匹配一个或多个字符组合(单词)%% 
/* 规则部分:模式 + 动作 *//* 当匹配到"while"时,打印该词 */
while  { printf("%s\n", yytext); }/* 当匹配到单词时,增加单词计数器 */
{words} { wordCount++;     // 单词数量加1
} /* 当匹配到空白符时,不执行任何操作 */ 
{whitespace} { /* 空动作:忽略空白字符 */ 
} /* 当匹配到数字时,增加数字计数器 */
([0-9])+ { numCount++;      // 数字数量加1
} %%  
/* 用户自定义代码部分 *//* 主函数 */
void main() { printf("ok1\n");          // 调试信息,表示程序开始运行yylex();                  // 启动词法分析printf("ok2\n");          // 调试信息,表示词法分析结束// 打印统计结果printf("No of words: %d\nNumber: %d\n", wordCount, numCount);  return 0;  
}/* 必须定义的yywrap函数(当输入文件结束时调用) */
int yywrap() { return 1;  // 返回1表示处理结束
} 

测试的文本:b.c

asd asdf 23 q 
a1 
b2
!#@
while

程序的输出

ok1
!#@while
ok2
No of words: 5number: 3
  • 简单分析一下输出结果
(1)这个ok1和ok2都是.lex程序中定义的输出
(2)其中!#@是没哟被匹配到的,所以会默认输出,这个while的话,.lex中规定了,遇到while就输出
(3)统计结果
wordCount = 5(asd, asdf, q, a, b)
numCount = 323, 1, 2

所要做的任务

在这里插入图片描述

  • 说白了,就需要你自己设计这个 a.lex 构词规则序列
  • 然后使用flex来生成词法生成程序lex.yy.c

在这里插入图片描述

flex a.lex 
gcc -o a lex.yy.c -lfl 
  • 自己设计b.c程序
  • 然后使用lex.yy.c来分析b.c

在这里插入图片描述

a.exe <b.c> a.txt 

在这里插入图片描述

实战

  • 当然是自己写啦

  • 我写的测试文件是 input.txt

关键字:东莞软件开发企业_中企动力科技股份有限公司成都分公司_营业推广的方式有哪些_南京高端品牌网站建设

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

责任编辑: