12、C语言和设计模式(解释器模式)
2015-08-08 22:46
363 查看
【 声明:版权所有,欢迎转载,请勿用于商业用途。 联系信箱:feixiaoxing @163.com】
解释器模式虽然听上去有些费解,但是如果用示例说明一下就不难理解了。我们知道在C语言中,关于变量的定义是这样的:一个不以数字开始的由字母、数字和下划线构成的字符串。这种形式的表达式可以用状态自动机解决,当然也可以用解释器的方式解决。
[cpp]
view plaincopy
typedef struct _Interpret
{
int type;
void* (*process)(void* pData, int* type, int* result);
}Interpret;
上面的数据结构比较简单,但是很能说明问题。就拿变量来说吧,这里就可以定义成字母的解释器、数字解释器、下划线解释器三种形式。所以,我们可以进一步定义一下process的相关函数。
[cpp]
view plaincopy
#define DIGITAL_TYPE 1
#define LETTER_TYPE 2
#define BOTTOM_LINE 3
void* digital_process(void* pData, int* type, int* result)
{
UINT8* str;
assert(NULL != pData && NULL != type && NULL != result);
str = (UNT8*)pData;
while (*str >= '0' && *str <= '9')
{
str ++;
}
if(*str == '\0')
{
*result = TRUE;
return NULL;
}
if(*str == '_')
{
*result = TRUE;
*type = BOTTOM_TYPE;
return str;
}
if(*str >= 'a' && *str <= 'z' || *str >= 'A' && *str <= 'Z')
{
*result = TRUE;
*type = LETTER_TYPE;
return str;
}
*result = FALSE;
return NULL;
}
void* letter_process(void* pData, int* type, int* result)
{
UINT8* str;
assert(NULL != pData && NULL != type && NULL != result);
str = (UNT8*)pData;
while (*str >= 'a' && *str <= 'z' || *str >= 'A' && *str <= 'Z')
{
str ++;
}
if(*str == '\0')
{
*result = TRUE;
return NULL;
}
if(*str == '_')
{
*result = TRUE;
*type = BOTTOM_TYPE;
return str;
}
if(*str >= '0' && *str <= '9')
{
*result = TRUE;
*type = DIGITAL_TYPE;
return str;
}
*result = FALSE;
return NULL;
}
void* bottom_process(void* pData, int* type, int* result)
{
UINT8* str;
assert(NULL != pData && NULL != type && NULL != result);
str = (UNT8*)pData;
while ('_' == *str )
{
str ++;
}
if(*str == '\0')
{
*result = TRUE;
return NULL;
}
if(*str >= 'a' && *str <= 'z' || *str >= 'A' && *str <= 'Z')
{
*result = TRUE;
*type = LETTER_TYPE;
return str;
}
if(*str >= '0' && *str <= '9')
{
*result = TRUE;
*type = DIGITAL_TYPE;
return str;
}
*result = FALSE;
return NULL;
}
解释器模式虽然听上去有些费解,但是如果用示例说明一下就不难理解了。我们知道在C语言中,关于变量的定义是这样的:一个不以数字开始的由字母、数字和下划线构成的字符串。这种形式的表达式可以用状态自动机解决,当然也可以用解释器的方式解决。
[cpp]
view plaincopy
typedef struct _Interpret
{
int type;
void* (*process)(void* pData, int* type, int* result);
}Interpret;
上面的数据结构比较简单,但是很能说明问题。就拿变量来说吧,这里就可以定义成字母的解释器、数字解释器、下划线解释器三种形式。所以,我们可以进一步定义一下process的相关函数。
[cpp]
view plaincopy
#define DIGITAL_TYPE 1
#define LETTER_TYPE 2
#define BOTTOM_LINE 3
void* digital_process(void* pData, int* type, int* result)
{
UINT8* str;
assert(NULL != pData && NULL != type && NULL != result);
str = (UNT8*)pData;
while (*str >= '0' && *str <= '9')
{
str ++;
}
if(*str == '\0')
{
*result = TRUE;
return NULL;
}
if(*str == '_')
{
*result = TRUE;
*type = BOTTOM_TYPE;
return str;
}
if(*str >= 'a' && *str <= 'z' || *str >= 'A' && *str <= 'Z')
{
*result = TRUE;
*type = LETTER_TYPE;
return str;
}
*result = FALSE;
return NULL;
}
void* letter_process(void* pData, int* type, int* result)
{
UINT8* str;
assert(NULL != pData && NULL != type && NULL != result);
str = (UNT8*)pData;
while (*str >= 'a' && *str <= 'z' || *str >= 'A' && *str <= 'Z')
{
str ++;
}
if(*str == '\0')
{
*result = TRUE;
return NULL;
}
if(*str == '_')
{
*result = TRUE;
*type = BOTTOM_TYPE;
return str;
}
if(*str >= '0' && *str <= '9')
{
*result = TRUE;
*type = DIGITAL_TYPE;
return str;
}
*result = FALSE;
return NULL;
}
void* bottom_process(void* pData, int* type, int* result)
{
UINT8* str;
assert(NULL != pData && NULL != type && NULL != result);
str = (UNT8*)pData;
while ('_' == *str )
{
str ++;
}
if(*str == '\0')
{
*result = TRUE;
return NULL;
}
if(*str >= 'a' && *str <= 'z' || *str >= 'A' && *str <= 'Z')
{
*result = TRUE;
*type = LETTER_TYPE;
return str;
}
if(*str >= '0' && *str <= '9')
{
*result = TRUE;
*type = DIGITAL_TYPE;
return str;
}
*result = FALSE;
return NULL;
}
相关文章推荐
- 11、C语言和设计模式(备忘录模式)
- C++对象模型--总结
- 浅谈C/C++的浮点数在内存中的存储方式
- C语言的基础复习——scanf使用注意
- c语言中 switch case 和 if else执行效率的比较
- 排序算法的C语言实现-希尔排序
- 面试的算法1(C语言)(整理)(组合数 字符串倒置 最大公共串)
- C++学习(一)
- C++ 下的GDI+绘图初始配置
- C++面向对象高级开发No.2 - Class With Pointer
- C++面向对象高级开发No.1 - Class Without Pointer
- 为什么和其他语言相比C语言是快速的语言
- C语言:顺序结构(数组)的循环队列
- leetcode_Valid Anagram_easy
- C++中数字与字符串之间的转换
- 使用c/c++扩展python
- C++下实现形成文本的一种方法
- C++文件操作
- C语言堆栈入门——堆和栈的区别
- C++(33)模板与泛型之实例化