LEX & YACC 写的一个表达式计算程序

来源:互联网 发布:动漫二维码制作软件 编辑:程序博客网 时间:2024/06/06 09:39

前两天觉得LEX和YACC挺强大的,稍微写了一个处理表达式的程序

 

LEX文件:

 

YACC文件:

 

编译并运行:

lex expr.l  && yacc -d expr.y && gcc lex.yy.c y.tab.c -o expr -ll && echo "OK" && ./expr

 

 

附表达式的优先级表: 

http://www.cppreference.com/wiki/operator_precedence

 

Precedence Operator Description Example Overloadable Associativity 1::Scope resolution operatorClass::age = 2;nonone2()
()
[]
->
.
++
--
const_cast
dynamic_cast
static_cast
reinterpret_cast
typeidFunction call
Member initalization
Array access
Member access from a pointer
Member access from an object
Post-increment
Post-decrement
Special cast
Special cast
Special cast
Special cast
Runtime type informationisdigit('1')
c_tor(int x, int y) : _x(x), _y(y*10){};
array[4] = 2;
ptr->age = 34;
obj.age = 34;
for( int i = 0; i < 10; i++ ) cout << i;
for( int i = 10; i > 0; i-- ) cout << i;
const_cast<type_to>(type_from);
dynamic_cast<type_to>(type_from);
static_cast<type_to>(type_from);
reinterpret_cast<type_to>(type_from);
cout « typeid(type).name();yes
yes
yes
yes
no
yes
yes
no
no
no
no
noleft to right3!
not
~
compl
++
--
-
+
*
&
new
new []
delete
delete []
(type)
sizeofLogical negation
Alternate spelling for !
Bitwise complement
Alternate spelling for ~
Pre-increment
Pre-decrement
Unary minus
Unary plus
Dereference
Address of
Dynamic memory allocation
Dynamic memory allocation of array
Deallocating the memory
Deallocating the memory of array
Cast to a given type
Return size of an object or typeif( !done ) …

flags = ~flags;

for( i = 0; i < 10; ++i ) cout << i;
for( i = 10; i > 0; --i ) cout << i;
int i = -1;
int i = +1;
int data = *intPtr;
int *intPtr = &data;
long *pVar = new long;
MyClass *ptr = new MyClass(args);
delete pVar;
delete [] array;
int i = (int) floatNum;//int size = sizeof(float);yes

yes

yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
yes
noright to left4->*
.*Member pointer selector
Member object selectorptr->*var = 24;
obj.*var = 24;yes
noleft to right5*
/
%Multiplication
Division
Modulusint i = 2 * 4;
float f = 10.0 / 3.0;
int rem = 4 % 3;yes
yes
yesleft to right6+
-Addition
Subtractionint i = 2 + 3;
int i = 5 - 1;yes
yesleft to right7<<
>>Bitwise shift left
Bitwise shift rightint flags = 33 << 1;
int flags = 33 >> 1;yes
yesleft to right8<
<=
>
>=Comparison less-than
Comparison less-than-or-equal-to
Comparison greater-than
Comparison greater-than-or-equal-toif( i < 42 ) …
if( i <= 42 ) ...
if( i > 42 ) …
if( i >= 42 ) ...yes
yes
yes
yesleft to right9==
eq
!=
not_eqComparison equal-to
Alternate spelling for ==
Comparison not-equal-to
Alternate spelling for != if( i == 42 ) ...

if( i != 42 ) …
yes
-
yes
left to right10&
bitandBitwise AND
Alternate spelling for & flags = flags & 42;
yes
left to right11^
xorBitwise exclusive OR (XOR)
Alternate spelling for ^ flags = flags ^ 42;
yes
left to right12|
bitorBitwise inclusive (normal) OR
Alternate spelling for |flags = flags | 42;
yes
left to right13&&
andLogical AND
Alternate spelling for && if( conditionA && conditionB ) …
yes
left to right14||
orLogical OR
Alternate spelling for ||if( conditionA || conditionB ) ...
yes
left to right15? :Ternary conditional (if-then-else)int i = (a > b) ? a : b;noright to left16=
+=
-=
*=
/=
%=
&=
and_eq
^=
xor_eq
|=
or_eq
<<=
>>=Assignment operator
Increment and assign
Decrement and assign
Multiply and assign
Divide and assign
Modulo and assign
Bitwise AND and assign
Alternate spelling for &=
Bitwise exclusive or (XOR) and assign
Alternate spelling for ^=
Bitwise normal OR and assign
Alternate spelling for |=
Bitwise shift left and assign
Bitwise shift right and assignint a = b;
a += 3;
b -= 4;
a *= 5;
a /= 2;
a %= 3;
flags &= new_flags;

flags ^= new_flags;

flags |= new_flags;

flags <<= 2;
flags >>= 2;yes
yes
yes
yes
yes
yes
yes

yes

yes

yes
yesright to left17throwthrow exceptionthrow EClass(“Message”);no18,Sequential evaluation operatorfor( i = 0, j = 0; i < 10; i++, j++ ) …yesleft to right

原创粉丝点击