- 浏览: 661385 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
sztime:
可以在文本框上绑定事件来禁用回车键, 我就是这样做的.在IE中 ...
form 回车自动提交问题 -
damoqiongqiu:
非常好的文章,很透彻不过有一句话小僧腆着脸补充一下:“1111 ...
为什么要用补码来做存储 -
wuyizhong:
原来如此啊。
form 回车自动提交问题 -
luliangy:
谢楼主~!
用C语言扩展Python的功能 -
kwong:
很有用,谢谢
火狐和IE 对css 样式解释的差异
In web programming, we often use regular expression for validating the e-mail address or phone number. Regular expression is a powerful tool in validating the specific format field. However, the interpretation of regular expression is not an easy job.
In the GoF’s design patterns, there is a corresponding pattern named Interpreter.
Given a language, define a representation for its grammar along with an interpreter that uses the representation to interpret sentences in the language.
–By GOF BOOK
Maybe, from the intent, you’ll know that you won’t touch this pattern in your future career That’s what I think.
To illustrate this pattern, I’ll show you a demo for calculating an arithmetic expression. And the expression will only support addition and subtraction, so the expression may looks like “11 + 2 + 3 - 4 – 5 + 8”.
And the grammar we define as follows:
GeneralExpression => AddExpression | SubExpression | NumberExpression
AddExpression => GeneralExpression + NumberExpression
SubExpression => GeneralExpression - NumberExpression
NumberExpression => 0 | ([1-9][0-9]*)
Note: “|” means or.
Now, the expression “11 + 2 + 3 - 4 – 5 + 8”’s grammar tree can be describe as follows.
As you see, we can calculate the expression by parsing the expression from top to down. Now, we need to design the classes.
The class diagram is as follows.
When we get an expression, it’ll be passed to the GeneralExpression, then the interpret method will be called. The source code is as follows.
- public function interpret () : int
- {
- if ( exp . lastIndexOf ( " + " ) > exp . lastIndexOf ( " - " ))
- return new AddExpression ( exp ) . interpret () ;
- else if ( exp . lastIndexOf ( " + " ) < exp . lastIndexOf ( " - " ))
- return new SubExpression ( exp ) . interpret () ;
- else
- return new NumberExpression ( exp ) . interpret () ;
- }
And the interpret method of SubExpression or AddExpression maybe called, and here is the source code of interpret method in SubExpression.
- public function interpret () : int
- {
- var index : int = exp . lastIndexOf ( SUB ) ;
- var generalExp : String = exp . substr ( 0 , index ) ;
- var numberExp : String = exp . substr ( index + 1 , exp . length ) ;
- return new GeneralExpression ( generalExp ) . interpret ()
- - new NumberExpression ( numberExp ) . interpret () ;
- }
In the interpret method of each class will parsing the expression from top to down, then calculate the value and returns it.
As you see, this pattern is, eh, all about the complier I don’t like this pattern, because it’s uneasy to implement when the grammar is not so simple. Maybe it’s all because I haven’t learned the complier principle well. Download Full Project
Enjoy!
发表评论
-
设计模式 图析
2011-09-24 14:27 710【observer】 【adapter】 【comm ... -
一个设计模式的图片
2009-05-03 02:14 532... -
Design Patterns in ActionScript–Factory Method
2009-02-24 13:37 763In our last topic, we talk abou ... -
Design Patterns in ActionScript-Strategy
2009-02-24 13:34 567Today, we’re going to talk abou ... -
Design Patterns in ActionScript-Mediator
2009-02-24 13:29 502Ok, the last pattern now. Let’s ... -
Design Patterns in ActionScript-Command
2009-02-24 13:21 615A few months ago, I was an inte ... -
Design Patterns in ActionScript-Chain of Responsib
2009-02-24 13:12 594When you need some help in a ho ... -
Design Patterns in ActionScript-Flyweight
2009-02-24 13:07 631In Action Script 3.0 we have th ... -
Design Patterns in ActionScript-Visitor
2009-02-24 11:26 507It’s our winter holiday now, an ... -
Design Patterns in ActionScript-Memento
2009-02-23 23:38 511Now, I’m using Microsoft word t ... -
Design Patterns in Action Script-Composite
2009-02-23 14:29 509Still remember the Interpreter ... -
Design Patterns in ActionScript-Proxy
2009-02-23 14:19 623Have you ever use HTTP-proxy or ... -
Design Patterns in Action Script-State
2009-02-23 14:17 950Yesterday, when I was on my way ... -
Design Patterns in ActionScript-Builder
2009-02-23 14:16 516Have you ever buy a computer on ... -
Design Patterns in ActionScript-Prototype
2009-02-23 14:12 661When I want to write the Protot ... -
Design Patterns in ActionScript-Iterator
2009-02-23 14:07 568There is a famous saying in com ... -
Design Patterns in Action Script-Template Method
2009-02-23 14:04 493Do you like playing cards? If y ... -
Design Patterns in ActionScript-Observer
2009-02-23 14:00 589In GUI programming, event-drive ... -
Design Patterns in ActionScript-Singleton
2009-02-23 13:55 521In our real world, many things ... -
Design Patterns in Action Script-Bridge
2009-02-23 13:44 552I think many of you are the fan ...
相关推荐
Go Design Patterns for Real-World Projects 英文epub 本资源转载自网络,如有侵权,请联系上传者或csdn删除 本资源转载自网络,如有侵权,请联系上传者或csdn删除
Go Design Patterns for Real-World Projects 英文azw3 本资源转载自网络,如有侵权,请联系上传者或csdn删除 本资源转载自网络,如有侵权,请联系上传者或csdn删除
Data Structures and Algorithms with Object-Oriented Design Patterns in CSharp - Bruno R. Preiss
"Laracasts - design-patterns-in-php.torrent"则可能是一个BT种子文件,用于通过BitTorrent协议下载整个课程的大型数据包,这通常包括所有视频讲座和其他相关文件。 在课程"设计模式在PHP中"中,你可能会学到以下...
The topic of Design Patterns sounds dry, academically constipated and, in all honesty, done to death in almost every programming language imaginable—including programming languages such as JavaScript...
https://github.com/kamranahmedse/design-patterns-for-humans 中文翻译,实例修改位JAVA代码
Apply design patterns to modern C++ programming Use creational patterns of builder, factories, prototype and singleton Implement structural patterns such as adapter, bridge, decorator, facade and ...
《Kotlin设计模式实战解析》 在编程领域,设计模式是一种通用、可重用的...开源项目"Design-Patterns-In-Kotlin"则是一个很好的学习资源,它提供了各种设计模式在Kotlin中的具体实现,有助于开发者深入学习和实践。
Go: Design Patterns for Real-World Projects What You Will Learn: Install and configure the Go development environment to quickly get started with your first program Use the basic elements of the ...
《ActionScript设计模式》是软件开发领域中针对ActionScript编程语言的一种实践指南,它深入探讨了如何在ActionScript项目中应用经典的设计模式。设计模式是软件工程中的宝贵经验总结,它们是解决常见问题的可复用...
Java+Enterprise+Design+Patterns+-+Patterns+in+Java+Volume+3Java+Enterprise+Design+Patterns+-+Patterns+in+Java+Volume+3
《Pro-Objective-C-Design-Patterns-for-iOS》是一本专注于在iOS平台上利用Objective-C语言实现设计模式的专业书籍。书中旨在帮助已经有一定Cocoa开发基础的开发者,通过掌握设计模式的实践应用,提升软件开发的生产...
在本论文“2010-13-Design Patterns for Safety-Critical”中,作者Ashraf Armoush探讨了如何将设计模式的概念应用于安全关键嵌入式系统的开发。他构建了一个设计模式目录,这个目录包含了一系列针对硬件和软件的...
design pattern in C# language