`
java-mans
  • 浏览: 11422007 次
文章分类
社区版块
存档分类
最新评论

正则习点 --- 10

 
阅读更多

Chapter 4. The Mechanics ofExpression Processing

4.1. Start Your Engines!

4.1.1. Regex Engine Types

ØDFA (Deterministic FiniteAutomaton)

ØNFA (Nondeterministic FiniteAutomaton)

使用NFA的工具包括.NET、PHP、Ruby、Perl、Python、GNU Emacs、ed、sec、vi、grep的多数版本,甚至还有某些版本的egrep和awk。

4.1.2. Testing the Engine Type

如果我们想知道工具a或工具b使用何种引擎,写一段代码即可!

#! /usr/bin/perl -w

$testStr = "nfa not";

$testStr =~ /(nfa)|(nfa not)/;

print $testStr;

此代码测试Perl使用何种引擎。

4.2. Match Basics

4.2.1 About the Example

两条普适(DFA和NFA)的原则:

²优先选择最左端(最靠开头)的匹配结果。

²标准的匹配量词(「*」, 「+」, 「?」, and 「{m,n}」)是匹配优先的。

4.2.2. Rule 1: The Match ThatBegins Earliest Wins

匹配先从需要查找的字符串的起始位置尝试匹配。(the match is first attempted at the very beginning of the string tobe search (just before the first character))

所以,用「cat」匹配下列字符串:

Thedragging belly indicates that your cat is too fat.

结果是indicates,而不是后来出现的cat。单词cat是能够被匹配的,但是indicates中的cat出现的更早,所以得到匹配的是他。

4.2.3. Rule 2: The Standard Quantifiers Are Greedy

标准匹配量词总是尝试匹配尽可能多的字符,直到匹配上限(maximum allowed)为止。

4.3. Regex-Directed VersusText-Directed

4.3.1. NFA Engine:Regex-Directed

表达式中的控制权在不同的元素之间转换,我们称之为“表达式主导”。

引擎会不断地尝试匹配表达式中的元素,直到匹配成功或是报告失败。

4.3.2. DFA Engine: Text-Directed

扫描的字符串中的每个字符都对引擎进行了控制,我们称这种方式为“文本主导”。

DFA引擎在扫描字符串时,会纪录“当前有效(currently in the works)”的所有匹配可能。

分享到:
评论

相关推荐

    linux系统shell正则表达式-练习工具和教材

    linux系统shell正则表达式-练习工具和教材 正则表达式-练习工具和教材 正则表达式-练习工具和教材

    正则表达式 到 NFA

    这是编译原理的一个实验, 是把一个正则表达式转化为不确定有穷自动机NFA的算法程序,朋兴趣的朋友可以下载来看看哦. 一个正则表达式就是由普通字符(例如字符 a 到 z)以及特殊字符(称为元字符)组成的文字模式...

    各类正则表达式详细手册

    包括ORACLE+PLSQL正则表达式手册、详细的Javascript正则表达式参考手册、C#字符串和正则表达式参考手册

    正则表达式规则及常用正则表达式列举

    正则表达式规则及常用正则表达式列举,应该很全了

    Python-Flask

    basics - Bin-block 全局解释器锁练习源码 - Bin-Coroutine 协程练习源码 + Coroutine 协程练习源码 + greenlet 模块 - Bin-Thread 线程练习源码 - Bin-Multiprocessing 多进程练习 - Bin-Re 正则表达式练习 ...

    正则表达式经典案例学习讲解

    javascript的正则表达式的经典案例详解,从入门到熟练~

    正则表达式专题

    学习完正则表达式后,有必要通过一定的习题来检验自己的学习情况

    正则表达式学习笔记

    正 则 表 达 式 学 习 笔 记

    编译原理正则表达式转NFA转DFA DFA最小化 Cpp代码

    编译原理课的大作业 包含三个小实验 在一个cpp文件里 正则表达式转换为nfa nfa转换为dfa dfa最小化 个人原创代码

    模式分类PatternClassificationSecondEdition中译本-模式分类.part1.rar

    6.11正则化复杂度调节和剪枝 本章小结 文献和历史评述 习题 上机练习 参考文献 ------------------- 第七章随机方法 7.1引言 7.2随机搜索 7.3学习 7.4网络和图示模型 7.5进化方法 7.6规则 本章小结 ...

    模式分类PatternClassificationSecondEdition中译本-模式分类.part2.rar

    6.11正则化复杂度调节和剪枝 本章小结 文献和历史评述 习题 上机练习 参考文献 ------------------- 第七章随机方法 7.1引言 7.2随机搜索 7.3学习 7.4网络和图示模型 7.5进化方法 7.6规则 本章小结 ...

    老王Python基础+进阶+项目篇(高清无密)

    基础篇10-python基本数据结构-列表应用 基础篇11-python基本数据结构-元组和集合 基础篇12-python基本数据结构-字典 基础篇13-python基本数据结构习题解答 基础篇14-答疑课-python里面这些难缠的符号们 基础篇15-...

    编译原理习题答案3-3

    这个资源有问题,已损坏,需要的朋友请下载“编译原理第三部分(重发)”,给大家带来麻烦对不起了~~~ 西北工业大学出版,第三版,蓝色封面,课后习题答案,一共三个部分,可单独解压,

    正则表达式匹配IP的表达式(推荐)

    这里给大家详细讲解一下一个匹配IP地址的正则表达式,  有关正则方面的知识,会在详细的讲解中提到。  在讲解之前,我先给大家介绍一下,ip地址的生成规则。  IP地址,是由32位数字二进制转为四个十进制的字符串...

    正则表达式

    此课程较全面的讲解了正则表达式,之后还有习题供做训练。适合初学者。

    实数变函数和范函分析(南开大学下载)

    第 5 讲 不动点原理及应用 第 6 讲 紧集与连续映射 第 7 讲 紧性与有限维空间 第 8 讲 积空间与商空间 习 题 一 第二章 有界线性算子与有界线性泛函 第 9 讲 空间 B(X, Y) 与 X* 第 10 讲 共鸣...

    JAVA开发实战经典

    JAVA开发实战经典课后习题讲解第11章:正则习题讲解

    正则表达式入门学习经典

    包含一些实例,以及课件习题,同样也包含一些可供开发时参考的代码,又陷入深。

    金成值书后习题第四章

    第四章详细答案解析 文法与语法分析,文法的二义性,等价文法,算法,正则nfa,dfa到正则文法的转换,判断文法是LL(1)文法,文法分析表,文法分析过程

    Perl语言入门(第五版-中文版).pdf

    本书的诸位作者自1991年起就开始在stonehenge consulting从事perl教学工作,多年的课堂教学实践和积累下来的点滴经验,形成了本书特有的教学节奏,以及务实的知识点取舍。随文而至的习题,可以让你及时巩固各种概念...

Global site tag (gtag.js) - Google Analytics