无法链接lex库

执行cc   lex.yy.c   -o    filename   -ll错误:

ERROR:/usr/bin/ld: cannot   find   -ll

collect  2:   ld  returned  1 exist status.


原因:无法链接到lex库


解决方法:建立到flex库的链接即可

 

ln  -sv  libfl.a  /usr/lib/libl.a

cat > /usr/lib/lex << "EOF"

     exec /usr/lib/flex -l  "$#"

EOF

 

chmod -v 755 /usr/bin/lex

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
作者: 胡彦 本框架是一个lex/yacc完整的示例,用于学习lex/yacc程序基本的搭建方法,在linux/cygwin下敲入make就可以编译和执行。 本例子虽小却演示了lex/yacc程序最常见和重要的特征: * lex/yacc文件格式、程序结构。 * 如何在lex/yacc中使用C++和STL,用extern "C"声明那些lex/yacc生成的、要链接的C函数,如yylex(), yywrap(), yyerror()。 * 重定义YYSTYPE/yylval为复杂类型。 * 用%token方式声明yacc记号。 * 用%type方式声明非终结符的类型。 * lex里正则表达式的定义、识别方式。 * lex里用yylval向yacc返回属性值。 * 在yacc嵌入的C代码动作里,对记号属性($1, $2等)、和非终结符属性($$)的正确引用方法。 * 对yyin/yyout重赋值,以改变yacc默认的输入/输出目标。 * 如何开始解析(yyparse函数),结束或继续解析(yywrap函数)。 本例子功能是,对当前目录下的file.txt文件,解析出其中的标识符、数字、其它符号,显示在屏幕上。linux调试环境是Ubuntu 10.04。 总之,大部分框架已经搭好了,你只要稍加扩展就可以成为一个计算器之类的程序,用于《编译原理》的课程设计。 文件列表: lex.l: lex程序文件。 yacc.y: yacc程序文件。 main.hpp: 共同使用的头文件。 Makefile: makefile文件。 file.txt: 给程序解析的文本文件。 使用方法: 1-把lex_yacc_example.rar解压到linux/cygwin下。 2-命令行进入lex_yacc_example目录。 3-敲入make,这时会自动执行以下操作: (1) 自动调用flex编译.l文件,生成lex.yy.c文件。 (2) 自动调用bison编译.y文件,生成yacc.tab.c和yacc.tab.h文件。 (3) 自动调用g++编译、链接出可执行文件main。 (4) 自动执行main,得到如下结果:。 bison -d yacc.y g++ -c lex.yy.c g++ -c yacc.tab.c g++ lex.yy.o yacc.tab.o -o main id: abc id: defghi int: 123 int: 45678 op: ! op: @ op: # op: $ AllId: abc defghi 参考资料:《Lex和Yacc从入门到精通(6)-解析C-C++包含文件》, http://blog.csdn.net/pandaxcl/article/details/1321552 其它文章和代码请留意我的blog: http://blog.csdn.net/huyansoft 2013-4-27
链接器和加载器殿堂级经典书籍 不管你的编程语言是什么,不管你的平台是什么,你很可能总是会涉及链接器和加载器的功能。但是你知道如何最大限度地利用它们吗?只有现在,随着《链接器和加载器》的出版,总算有一本深入完整地彻底揭示编译时和运行时过程的权威著作了。 《链接器和加载器》首先通过实例深入浅出地阐述了在不同的编译器和操作系统中链接和加载过程的差异。在这个基础上,作者提出了清晰实用的忠告,来帮助你创建更快、更清晰的代码。你将会学习如可规避和Windows DLL相关的陌阱,充分利用UNX ELF模式等。如果你对程序设计抱有非常认真的态度,那么你可以通过这本书充分地理解这个领域内最难惶的主题之一。《链接器和加载器》对于编译器和操作系统课程同样也是一本理想的补充读物, 本书特性 覆盖了 windows,UNIX,LInux Beos和其它操作系统的动态链接过程。 解释了Java链接模式,以及它是如何应用在网络小应用程序和可扩展Java代码中的。 帮助你编写更优雅、更高效的代码,以及构建能够被更加高效地编译、加载和运行的应用程序。 包含了一个用Perl构建链接器的练习项目,项目文件可以从网络下载得到。 John R. Levine是很多书籍的作者或合作者,包括Lex&Yacc;(O'Reilly), Programming for Graphics Files in C and C++(Wiley),以及The Internet for Dummies (IDG),他还是Journal ofcLanguage Translation的荣誉退休发行人、comp.compilers新闻组的长期仲裁人员,以及某个最早的商用Fortran 77编译器的创建者。他在耶鲁大学获得了计算机科学的博士学位。
要使用 Calcite 连接本地 MySQL 数据,您需要遵循以下步骤: 1. 下载 Calcite JDBC 驱动程序 jar 文件。可以在 Maven Central 上找到最新版本的 Calcite JDBC 驱动程序 jar 文件。 2. 将下载的 Calcite JDBC 驱动程序 jar 文件放置在您的应用程序的类路径下。 3. 创建一个包含 MySQL 连接信息的 JSON 配置文件,例如: ``` { "version": "1.0", "defaultSchema": "MY_SCHEMA", "schemas": [ { "type": "jdbc", "name": "MY_SCHEMA", "jdbcDriver": "com.mysql.jdbc.Driver", "jdbcUrl": "jdbc:mysql://localhost:3306/my_database", "jdbcUser": "my_user", "jdbcPassword": "my_password" } ] } ``` 4. 使用上面的配置文件创建一个 Calcite 的 JDBC 数据源,例如: ```java Properties info = new Properties(); info.setProperty("lex", "JAVA"); info.setProperty("quoting", "DOUBLE_QUOTE"); info.setProperty("unquotedCasing", "TO_UPPER"); CalciteConnection connection = DriverManager.getConnection("jdbc:calcite:model=my_model.json", info).unwrap(CalciteConnection.class); ``` 其中,`my_model.json` 是上面创建的 JSON 配置文件的路径。 5. 通过 JDBC 数据源连接到 MySQL 数据,例如: ```java Statement statement = connection.createStatement(); ResultSet resultSet = statement.executeQuery("SELECT * FROM my_table"); while (resultSet.next()) { // 处理查询结果 } ``` 这就是连接本地 MySQL 数据的基本步骤。当然,具体的实现方式可能会有所不同,具体取决于您的应用程序的架构和需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值