首先在编辑器中创建一个新文件并将其命名为"uppercase.lex"。
编写以下代码:
%{ int count = 0; %}
%% ^[A-Z][a-zA-Z]*[a-z]$ {count++;} . {} %%
在编写lex程序时,我们必须使用类似C语言的语法。因此,在此程序中,我们使用C语言中用于声明变量的语法(例如,int count=0;)来声明一个变量count,以便计算匹配模式的数量。
在程序的第一个模块中,在%%之前,我们使用正则表达式指定要匹配的模式。在此例中,我们要匹配以大写字母开头,以小写字母结尾的单词。^[A-Z]指单词的首字母是大写字母,[a-zA-Z]*表示中间的字符可以是大写或小写字母,[a-z]$表示单词以小写字母结尾。
在代码的第二个模块中,我们使用大括号定义对于每个匹配模式应执行的操作。在此例中,我们使用计数器(count++)来计算匹配模式的数量。
最后,由于我们只想匹配以大写字母开头,以小写字母结尾的模式,而不会对其他字符进行任何操作,因此我们可以在代码中使用.表示忽略所有其他字符。
$ lex uppercase.lex
$ gcc lex.yy.c -o uppercase -ll
$ ./uppercase