我正在尝试使用reentrant lex和yacc编写一个简单的计算器应用程序。这里我希望创建两个线程(解析器),它应该解析输入文件中提供的输入。要在输入文件中解析的行分为两个线程..
我的简单计算器的lex代码是
%option reentrant bison-bridge
%option noyywrap
%{
#include<stdio.h>
void yyerror(char *);
#include "y.tab.h"
%}
%%
[0-9]+ {
yylval=atoi(yytext);
return INTEGER;
}
[-+\n] return *yytext;
[ \t] ;/* Skip whitespaces*/
. ;
%%
我的简单计算器yacc文件(可重入)是
%pure-parser
%lex-param {void * scanner}
%parse-param {void * scanner}
%{
#include <pthread.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include<stdio.h>
#include <stdlib.h>
int f[2];
pthread_mutex_t lock;
int cnt=0;
void* scanfunc(void * );
%}
%token INTEGER
%%
program: program expr '\n' {printf("%d\n", $2);}
|
;
expr: INTEGER {$$=$1;}
|expr '+' expr {$$=$1+$3;}
|expr '-' expr {$$=$1-$3;}
;
%%
void yyerror(char *s){
fprintf(stderr,"%s\n",s);
}
int main(int argc, char *argv[]){
pthread_t threads[2];
int n=2,i;//Number of threads to be created
//set_file_ptr();
if(argc!=2){
printf("Insufficient nos. of arguments\n");
exit(0);
}
for(i=0;i<n;i++){
f[i]=open(argv[1],O_RDONLY);
lseek(f[i],i*30,SEEK_SET);
}
printf("File pointer set\n");
pthread_mutex_init(&lock,NULL);
for(i=0;i<n;i++){
pthread_create(&threads[i], NULL, (void *)scanfunc, (void *)&i);
}
//join all threads
for(i=0;i<n;i++){
pthread_join(threads[i],NULL);
}
pthread_mutex_destroy(&lock);
//yyparse();
return 0;
}
void* scanfunc(void * i)
{
void * scanner;
// printf("Value of i is %d\n",*(int *)i);
printf("Starting thread %d...\n", *(int *)i);
yylex_init(&scanner);
printf("Done scanner init\n");
pthread_mutex_lock(&lock);
printf("Thread with id %d obtained lock\n",cnt);
yyset_in(f[cnt],scanner);
cnt++;
pthread_mutex_unlock(&lock);
yyparse(scanner);
yylex_destroy(scanner);
}
我的输入文件是
12+12
14-12
23-11
12-12
23-45
67+45
11+23
45-12
67-12
90-34
56-56
90-45
当我编译并运行这个程序时,我得到了followign输出
File pointer set
Starting thread 0...
Starting thread 0...
Done scanner init
Thread with id 0 obtained lock
Done scanner init
Thread with id 1 obtained lock
Segmentation fault (core dumped)
当我使用gdb调试这个程序时,它说程序接收到信号SIGSEGV,在下面的行中出现分段错误。
yyparse(scanner);
我无法找到如何调试此程序。 感谢他的帮助。 谢谢
答案 0 :(得分:0)
yyin
必须是FILE*
,而不是int
。通过预计int
的{{1}}不会有令人愉快的结果;段错误不是意料之外的。
当你试图编译那段代码时,我很惊讶你没有得到一堆警告。
答案 1 :(得分:0)
解决了警告的问题:赋值来自整数而没有强制转换yylval = atoi(yytext);
推荐Making bison/flex parser reentrant with integral YYSTYPE帖子以了解我必须在代码中进行以下更改以消除警告。
*yylval=atoi(yytex)
谢谢