1.LԴ?源译????
2.64位系统上源码编译32位libcurl库
3.linux å¦ä½è¿è¡ç¼è¯ç¨åº
4.Linux下源码安装的经验详解
LԴ?????
Lex,Flex,码编Yacc,源译bison是码编编译原理中常用的工具,分别用于词法分析和语法分析。源译Lex(或Flex)生成词法分析器,码编快乐逃顶指标源码将字符流转换为标记;Yacc(或bison)生成语法分析器,源译执行语法规则解析。码编使用场景主要在编译器前端阶段,源译分别进行词法和语法分析。码编工作原理分别是源译通过正则表达式和BNF来描述规则并生成代码。
Lex与Flex相似,码编后者生成的源译扫描器具有可重入性,适用于多线程环境。码编Yacc与bison等效,源译后者具备更多功能与优化的错误报告,同样支持多线程,通过BNF描述语法规则生成代码。
综上,Lex和Flex用于生成词法分析器,海贼源码Yacc和bison用于生成语法分析器,共同构成编译器的核心部分。这些工具通过将词法或语法规则转化为C语言代码,实现源代码到目标代码的转换。
拓展内容:Lex文件通常包含三部分:定义、规则和C代码。以下是一个简单的Lex文件示例,用于将输入文本分割成单词和数字,并输出它们。将此文件保存为`lexer.l`,使用Lex工具生成词法分析器。步骤如下:编写Lex文件,使用`lex lexer.l`生成C文件`lex.yy.c`,通过C编译器编译文件`gcc lex.yy.c -o lexer`,最后运行生成的程序`./lexer`。
位系统上源码编译位libcurl库
有时候需要交叉编译libcurl,比如目标机器是位系统的,但是本地机器是位系统的,而且由于某些原因,雕刻源码我们无法在位系统上直接编译,所以需要用到交叉编译
libcurl是依赖openssl的,所以先编译openssl的位库 完整编译选项配置如下:
详细选项含义如下:预先已经export CC的版本 配置-m指定编译位的库 配置–prefix指定openssl的安装目录 配置–openssldir指定openssl的头文件目录 配置shared关键字指定编译时生成动态库(libssl.so/libcrypto.so及其相关软连接)然后再make && make install即可
有时候有的系统是默认安装了位zlib库的,那么就可以跳过这一步,但是有的系统需要自己下载编译zlib-位库 完整编译选项配置如下:直接修改CMakeLists.txt文件,增加以下两行 set(CMAKE_C_FLAGS “-m”) set(CMAKE_CXX_FLAGS “-m”) 详细选项含义如下:配置CMAKE_C_FLAGS指定编译位库环境 配置CMAKE_CXX_FLAGS指定编译位库环境然后再mkdir build && cd build && cmake .. && make && make install即可
最后就是编译libcurl 完整编译选项配置如下:
详细选项含义如下:配置PKG_CONFIG_PATH指定启动openssl选项(启动这个选项,就会默认链接lssl,lcrypto,lz三个库) 配置CFLAGS指定编译位库环境 配置CPPFLAGS指定链接的库的头文件 配置LDFLAGS指定链接的库的路径然后再make && make install即可
当编译第三方库的时候,如果有CMakeLists.txt,直接用CMakeLists.txt编译就很方便;如果只有configure,那么需要先了解编译选项执行./configure –help来查看当前支持的编译选项然后根据提示配置一下我们需要指定的选项,比如自己指定的openssl的版本的库和头文件路径名,比如CC的版本,比如安装路径等等 (当然,如果不需要额外配置这些东西的话,直接走默认配置的话,那么直接执行./config或者./configure就行)然后在生成Makefile之后,再make && make install即可
linux å¦ä½è¿è¡ç¼è¯ç¨åº
gccæå¤è¾¾å¤ä¸ªåæ°ï¼ç°ä»ç»å¸¸ç¨çå 个ãå¦æå¯¹å ¶ä»åæ°ä¹æå ´è¶£ï¼å¯ä»¥åèï¼man gcc
é¢å å¤çé项
-Eï¼ åªå¯¹æ件è¿è¡é¢å¤çï¼è¾åºç»æå°æ åè¾åº
-Cï¼ åè¯é¢å¤çå¨ä¸è¦ä¸¢å¼æ³¨é.é å`-Eâé项使ç¨.-Pï¼ åè¯é¢å¤çå¨ä¸è¦äº§ç`#line'å½ä»¤.é å`-E'é项使ç¨.
-vï¼ æ¾ç¤ºæ£å¨ä½¿ç¨çgccççæ¬
常ç¨ç¼è¯é项
-c: å°æºç¨åºç¼è¯ä¸ºç®æ 代ç ä½å¹¶ä¸åé¾æ¥çå·¥ä½ï¼ä¸çææç»çå¯æ§è¡æ件ï¼åªçæä¸ä¸ªä¸æºæ件æ件åç¸åç以.o为åç¼çç®æ æ件ã
-Sï¼å°è¿ç¨åºç¼è¯ä¸ºä¸ä¸ªåç¼ä¸º.sçæ±ç¼è¯è¨æ件ï¼ä¸ä¼çæå¯æ§è¡æ件
-xï¼å¼ºå¶ç¼è¯å¨ç¨æå®çè¯è¨ç¼è¯å¨æ¥ç¼è¯æ个æºæ件
gcc -x c++ test.c 表示强å¶ç¨C++ç¼è¯å¨æ¥ç¼è¯cç¨åº
-staticï¼ å¼ºå¶è¿æ¥éæåºï¼è¿è¡æ¶ä¸ä¾èµå¨æåº
-shareï¼ ç¼è¯æ¶å°½é使ç¨å¨æåº
-oï¼ æå®çæçå¯æ§è¡æ件åï¼å¦æ没æ该é项ï¼å¦æçæå¯æ§è¡æ件ï¼é»è®¤æ件å为a.out
ç¼è¯è·¯å¾é项
-i ï¼ æå®ç¹å®å¤´æ件
gcc âc -i /home/zry/test.h test.c
-I<DIR>:ãä¾èµé项ï¼æå®å¤´æ件路å¾
Linuxä¸å¤§å¤æ°å½æ°å°å¤´æ件æ¾å¨/usr/includeç®å½ä¸ï¼å¦æéè¦æå®å ¶ä»è·¯å¾ï¼å¯ä»¥ä½¿ç¨è¯¥é项
gcc âI/home/zry/include âc test.c æ·»å /home/zry/includeå°æ¥æ¾è·¯å¾
-L<DIR> : æå®åºæ件æç´ è·¯å¾ï¼ç¨æ³åä¸
-l<åºå>ï¼æå®ç¹å®åºæ件
gcc âlapp âc test.c
Linuxçåºæ件æä¸ä¸ªçº¦å®ï¼å³ä»¥libå¼å¤´ï¼-lapp表示è¿æ¥libapp.soåºæ件
ç®æ çæé项
-sharedï¼ çæå¨æåº
gcc âshared libtest.so -i /home/zry/test.h test.c
çæéæåºéè¦arå½ä»¤ï¼åé¢è®²è§£
-fPIC: çæå¯ç¨äºå¨æåºçä½ç½®ç¬ç«ä»£ç ãææçå é¨å¯»ååéè¿å ¨å±å移表å®æã
-ansiï¼æ¯æ符åANSIæ åçCç¨åº.
该é项就ä¼å ³éGNU Cä¸æäºä¸å ¼å®¹ANSI Cçç¹æ§,efa源码ä¾å¦asm, inlineå typeofå ³é®å以å诸å¦unixåvaxè¿äºè¡¨æå½åç³»ç»ç±»åçé¢å®ä¹å®ã
__asm__, __extension__, __inline__å__typeof__ä»ç¶ææ
使ç¨`-ansi'é项çæ¶å,é¢å¤çå¨ä¼é¢å®ä¹ä¸ä¸ª__STRICT_ANSI__å®.æäºå¤´æ件 å ³æ³¨æ¤å®,以é¿å 声ææäºå½æ°,æè é¿å å®ä¹æäºå®,è¿äºå½æ°åå®ä¸è¢«ANSIæ åè°ç¨;è¿æ ·å°±ä¸ä¼å¹²æ°å¨å ¶ä»å°æ¹ä½¿ç¨è¿äºååçç¨åºäº.
fno-asmï¼æ¤é项å®ç°ansié项çåè½çä¸é¨åï¼å®ç¦æ¢å°asm,inlineåtypeofç¨ä½å ³é®åã
-fno-strict-prototypeï¼åªå¯¹g++èµ·ä½ç¨,使ç¨è¿ä¸ªé项,g++å°å¯¹ä¸å¸¦åæ°çå½æ°,é½è®¤ä¸ºæ¯æ²¡ææ¾å¼ç对åæ°ç个æ°åç±»å说æ,èä¸æ¯æ²¡æåæ°.ègccæ 论æ¯å¦ä½¿ç¨è¿ä¸ªåæ°,é½å°å¯¹æ²¡æ带åæ°çå½æ°,认为没ææ¾å¼è¯´æçç±»å
-fthis-is-varialbleï¼å°±æ¯åä¼ ç»c++çé½,å¯ä»¥ä½¿ç¨thiså½ä¸è¬åé使ç¨
-fcond-mismatchï¼å 许æ¡ä»¶è¡¨è¾¾å¼ç第äºå第ä¸åæ°ç±»åä¸å¹é ,表达å¼çå¼å°ä¸ºvoidç±»å
-funsigned-charï¼
-fno-signed-charï¼
-fsigned-char:
-fno-unsigned-char:
è¿å个åæ°æ¯å¯¹charç±»åè¿è¡è®¾ç½®,å°charç±»å设置unsigned char(å两个åæ°)æè signed char(å两个åæ°)
-imacros file: å°fileæ件çå®,æ©å±å°gcc/g++çè¾å ¥æ件,å®å®ä¹æ¬èº«å¹¶ä¸åºç°å¨è¾å ¥æ件ä¸
-Dmacro: ç¸å½äºCè¯è¨ä¸ç#define macro
-Dmacro=defn: ç¸å½äºCè¯è¨ä¸ç#define macro=defn
-Umacro: ç¸å½äºCè¯è¨ä¸ç#undef macro
-undef: åæ¶å¯¹ä»»ä½éæ åå®çå®ä¹
-M: çææä»¶å ³èçä¿¡æ¯ãå å«ç®æ æ件æä¾èµçæææºä»£ç
-MM: åMä¸æ ·ï¼ä½æ¯å®å°å¿½ç¥ç±#include<file>é æçä¾èµå ³ç³»ã
-MD: -Mç¸åï¼ä½æ¯è¾åºå°å¯¼å ¥å°.dçæ件éé¢
-MMD: å-MMç¸åï¼ä½æ¯è¾åºå°å¯¼å ¥å°.dçæ件éé¢
è¦åé项
fsyntax-onlyï¼æ£æ¥ç¨åºä¸çè¯æ³é误,ä½æ¯ä¸äº§çè¾åºä¿¡æ¯.
-wï¼ç¦æ¢ææè¦åä¿¡æ¯.
-Wno-importï¼ ç¦æ¢ææå ³äº#importçè¦åä¿¡æ¯.
-pedanticï¼æå¼å®å ¨éµä»ANSI Cæ åæéçå ¨é¨è¦åè¯æ;æç»æ¥åéç¨äºè¢«ç¦æ¢çè¯æ³æ©å±çç¨åº.
-Werrorï¼å°ææè¦å转æ¢ä¸ºé误
Werroré项è¦æ±GCCå°ææè¦åå½ä½é误è¿è¡å¤çã
-Wallï¼ æ¾ç¤ºææè¦åä¿¡æ¯
Linux下源码安装的经验详解
在linux下安装软件,难免会碰到需要源码安装的,而就是这简简单单的./configure、make、sudo make install三步,却让不少人头疼不已,这里以安装X为例具体介绍下我在安装时的一点小经验,以便共同学习,共同进步!
首先,我们要做些准备工作,源码安装少不了这几个工具pkg-config、libtool、autoconf和automake(当然,还有更基础的,像zlib、m4等,这里就略过啦),其中,pkg-config是nnh源码相对比较重要的,它就是向configure程序提供系统信息的程序,如软件的版本、库的版本以及库的路径等信息,这些只是在编译期间使用。你可以打开/usr/lib/pkgconfig下任意一个.pc文件,就会发现类似下面的信息(X的pc文件):
prefix=/usr
exec_prefix=${ prefix}
libdir=${ exec_prefix}/lib
includedir=${ prefix}/include
xthreadlib=-lpthread
Name: X
Description: X Library
Version: 1.3.3
Requires: xproto kbproto
Requires.private: xcb = 1.1.
Cflags: -I${ includedir}
Libs: -L${ libdir} -lX
Libs.private: -lpthread
configure就是靠着这些信息来判断软件版本是否符合要求的。接着来看看pkg-config是怎样工作的,缺省情况下,pkg-config首先在usr/lib/pkgconfig/中查找相关包(譬如x)对应的相应的文件(x.pc),若没有找到,它也会到PKG_CONFIG_PATH这个环境变量所指定的路径下去找,若是还没有找到,它就会报错。所以这里就可以得到一些解决configure时提示**库未找到的办法了,先用命令ldconfig -p | grep 库名来分析该库是否安装及其路径,若返回空,则说明该库确实未安装,否则,可以根据该命令的返回结果找到库的安装地点,然后设置其环境变量,命令如下:
export PKG_CONFIG_PATH=软件位置/lib/pkgconfig:$PKG_CONFIG_PATH,这里有个常识,软件安装后,.pc文件都是在安装目录下的lib/pkgconf中的。这样只会在当前命令窗口有效,当然,你也可以修改home文件夹下的.bashrc文件(带.的文件为隐藏文件,可以用命令vi .bashrc编辑),在文件末尾加上上面那句命令,重新登录即可。其他的几个在linux下也是不可或缺的,libtool为管理library时使用,没装的话错误提示如下:possibly undefined macro:AC_PROG_LIBTOOL。而autoconf和automake可以用于在某些没有configure的文件的源码包安装时使用(pixman就是个典型的例子,安装了二者后直接./autogen.sh就可以安装了)。
准备工作做好后,就可以安装了,具体全部命令如下:
tar vxf libX-6.2.1.tar.gz
cd libX-6.2.1
mkdir X-build
cd X-build
../configure prefix=/usr/local/XR6
make
echo $
sudo make install
这里有一些好的安装习惯可以积累一下:1、建立一个临时编译目录,本例中为X-build,这样可以再安装完成后删除该目录,进而可以节省空间,而且保持了源码目录的整洁;2、安装到指定目录,本例中为/usr/local/XR6,最好把几个相关的安装在同一文件夹下,如这里的XR6文件夹,这样便于管理,否则全部默认安装在/usr/local下,很杂乱;3、编译完成后做检查,本例为echo $,表示检查上一条命令的退出状态,程序正常退出返回0,错误退出返回非0,也可以使用make check,主要为了防止make失败后直接install,进而出现了一些莫名其妙的错误。这里还介绍一种更方便快捷的安装方法,用将安装命令连接起来,如../configure prefix=**makesudo make install,这样,只有在前面的命令执行正确的情况下,后面的任务才会执行,多方便!
除此之外,安装之前可以阅读下源码包中的readme和install等文档,往往有所需软件及其下载地址,还包括一些安装技巧和配置选项。另外,在configure前,先输入configure help,可以查看有哪些选项可以添加。还有几个关系安装成功的东西就是ldconfig了,在安装时如果提示找不到某个库或者在编译时提示找不到**.so文件,就要用到它了,最简单的解决办法就是sudo gedit /etc/ld.so.conf,在文件中加入**.so文件所在路径,再运行一下ldconfig就可以了,但是我对这个东西有阴影,不知道是因为用了虚拟机还是其他的原因,有7、8次我在运行完ldconfig后,Ubuntu就没办法打开任何窗口了,直接关机重启就更是进不去系统了,崩溃之,不知道有没有高手有解决办法。在这里提供一种代替ldconfig的办法,就是export LD_LIBRARY_PATH=*.so文件地址:$LD_LIBRARY_PATH,用它我就舒心多了,也就是麻烦点,哥忍了,总比系统崩溃强多了吧,呵呵!其实,在configure时碰到问题,你应该庆幸,因为你可以根据它很明显的提示找到缺失的东西装上,在配置下pkgconfig和ldconfig基本上就可以搞定了,但是make的时候就没那么简单了。
编译时提示最多的就是**东西未找到了,要么是库文件,要么是头文件,库文件用上面的ldconfig基本上就可以搞定,头文件的话需要配置包含的路径,和库的类似,命令如下:
export LD_INCLUDE_PATH=/usr/local/include:$LD_INCLUDE_PATH
在这个时候最重要的就是淡定了,循着丫的error往上找,像No such file or directory这样的错误提示肯定就在附近,找到了,include之就可以咯!