当前位置:  编程技术>其它
本页文章导读:
    ▪2011-03-04 20:26 Linux ./configure --prefix命令      http://hi.baidu.com/raybin_yang/item/52fb4315ed99de05d0d66da2 2011-03-04 20:26 Linux ./configure --prefix命令 http://blog.csdn.net/xiyangfan/archive/2010/02/24/5321790.aspx http://blog.dormforce.net/rox/2008/09/26/configure-prefixxxx%E7%9A%84%E4%B.........
    ▪CMU Computer Vision(16720) HW2 Bag-of-Words-based Object Classification      Steps:1 Representing the World with Visual Words1.1 Creating Visual Words1.2 Computing Visual Words2 Building a Recognition System2.1 Extracting Features2.2 Comparing Windows2.3 Building A Model of the Visual World2.4 Quantitative Evaluation  .........
    ▪关于Unix静态库和动态库的分析       关于Unix静态库和动态库的分析 基本概念 库有动态与静态两种,动态通常用.so为后缀,静态用.a为后缀。 例如:libhello.so libhello.a 为了在同一系统中使用不同版本的库,可以在库文件名后加.........

[1]2011-03-04 20:26 Linux ./configure --prefix命令
    来源:    发布时间: 2013-11-15
http://hi.baidu.com/raybin_yang/item/52fb4315ed99de05d0d66da2

2011-03-04 20:26
Linux ./configure --prefix命令

http://blog.csdn.net/xiyangfan/archive/2010/02/24/5321790.aspx

http://blog.dormforce.net/rox/2008/09/26/configure-prefixxxx%E7%9A%84%E4%BD%9C%E7%94%A8/

源码的安装一般由3个步骤组成:配置(configure)、编译(make)、安装(make install),具体的安装方法一般作者都会给出文档,这里主要讨论配置(configure)。Configure是一个可执行脚本,它有很多选项,使用命令./configure –help输出详细的选项列表,如下:
-bash-3.00# ./configure --help
Usage: configure [options] [host]
Options: [defaults in brackets after descriptions]
Configuration:
--cache-file=FILE     cache test results in FILE
--help             print this message
--no-create         do not create output files
--quiet, --silent     do not print `checking...' messages
--version           print the version of autoconf that created configure
Directory and file names:
--prefix=PREFIX       install architecture-independent files in PREFIX
                [/usr/local]
--exec-prefix=EPREFIX   install architecture-dependent files in EPREFIX
                [same as prefix]
--bindir=DIR         user executables in DIR [EPREFIX/bin]
……….(省略若干)
很多的选项,个人认为,你可以忽略其他的一切,但请把—prefix加上。这里以安装supersparrow-0.0.0为例,我们打算把它安装到目录 /usr/local/supersparrow,于是在supersparrow-0.0.0目录执行带选项的脚本./configure --prefix=/usr/local/supersparrow,执行成功后再编译、安装(make,make install);安装完成将自动生成目录supersparrow,而且该软件所有的文件都被复制到这个目录。为什么要指定这个安装目录?是为了以后的维护方便,如果没有用这个选项,安装过程结束后,该软件所需的软件被复制到不同的系统目录下,很难弄清楚到底复制了那些文件、都复制到哪里去了—基本上是一塌糊涂。

用了—prefix选项的另一个好处是卸载软件或移植软件。当某个安装的软件不再需要时,只须简单的删除该安装目录,就可以把软件卸载得干干净净;移植软件只需拷贝整个目录到另外一个机器即可(相同的操作系统)。

一个小选项有这么方便的作用,建议在实际工作中多多使用

---不指定prefix,可执行文件默认放在/usr /local/bin,库文件默认放在/usr/local/lib,配置文件默认放在/usr/local/etc。其它的资源文件放在/usr /local/share。要卸载这个程序,要么在原来的make目录下用一次make uninstall(前提是make文件指定过uninstall),要么去上述目录里面把相关的文件一个个手工删掉。指定prefix,直接删掉一个文件夹就够了。


jackdong 2013-01-04 14:47 发表评论

    
[2]CMU Computer Vision(16720) HW2 Bag-of-Words-based Object Classification
    来源:    发布时间: 2013-11-15
Steps:
1 Representing the World with Visual Words
1.1 Creating Visual Words
1.2 Computing Visual Words
2 Building a Recognition System
2.1 Extracting Features
2.2 Comparing Windows
2.3 Building A Model of the Visual World
2.4 Quantitative Evaluation
  

recognition rate is nearly 65%.




abilitytao 2013-01-04 16:06 发表评论

    
[3]关于Unix静态库和动态库的分析
    来源:    发布时间: 2013-11-15
关于Unix静态库和动态库的分析
基本概念

库有动态与静态两种,动态通常用.so为后缀,静态用.a为后缀。 例如:libhello.so libhello.a

为了在同一系统中使用不同版本的库,可以在库文件名后加上版本号为后缀,例如: libhello.so.1.0,由于程序连接默认以.so为文件后缀名。所以为了使用这些库,通常使用建立符号连接的方式。

ln -s libhello.so.1.0 libhello.so.1
ln -s libhello.so.1 libhello.so

1、使用库

当要使用静态的程序库时,连接器会找出程序所需的函数,然后将它们拷贝到执行文件,由于这种拷贝是完整的,所以一旦连接成功,静态程序库也就不再需要了。 然而,对动态库而言,就不是这样。动态库会在执行程序内留下一个标记指明当程序执行时,首先必须载入这个库。由于动态库节省空间,linux下进行连接的 缺省操作是首先连接动态库,也就是说,如果同时存在静态和动态库,不特别指定的话,将与动态库相连接。

现在假设有一个叫hello的程序开发包,它提供一个静态库libhello.a 一个动态库libhello.so,一个头文件hello.h,头文件中提供sayhello()这个函数

/* hello.h */
void sayhello();

另外还有一些说明文档。

这一个典型的程序开发包结构 与动态库连接 linux默认的就是与动态库连接,下面这段程序testlib.c使用hello库中的sayhello()函数

/*testlib.c*/
#include "hello.h"
int main()
{
    sayhello();
    return 0;
}

使用如下命令进行编译

$gcc -c testlib.c -o testlib.o

用如下命令连接:

$gcc testlib.o -lhello -o testlib

连接时要注意,假设libhello.so 和libhello.a都在缺省的库搜索路径下/usr/lib下,如果在其它位置要加上-L参数。与静态库连接麻烦一些,主要是参数问题。还是上面的例 子:

$gcc testlib.o -o testlib -WI,-Bstatic -lhello

注:这个特别的”-WI,-Bstatic”参数,实际上是传给了连接器ld. 指示它与静态库连接,如果系统中只有静态库当然就不需要这个参数了。如果要和多个库相连接,而每个库的连接方式不一样,比如上面的程序既要和 libhello进行静态连接,又要和libbye进行动态连接,其命令应为:

$gcc testlib.o -o testlib -WI,-Bstatic -lhello -WI,-Bdynamic -lbye
2、动态库的路径问题

为了让执行程序顺利找到动态库,有三种方法:

  • 把库拷贝到/usr/lib和/lib目录下。
  • 在LD_LIBRARY_PATH环境变量中加上库所在路径。例如动态库 libhello.so在/home/ting/lib目录下,以bash为例,使用命令: $export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/home/ting/lib
  • 修改/etc/ld.so.conf文件,把库所在的路径加到文件末尾,并执行ldconfig刷新。这样,加入的目录下的所有库文件都可见。
  • 3、查看库中的符号

    有时候可能需要查看一个库中到底有哪些函数,nm工具可以打印出库中的涉及到的所有符号。库既可以是静态的也可以是动态的。nm列出的符号有很多, 常见的有三种,一种是在库中被调用,但并没有在库中定义(表明需要其他库支持),用U表示;一种是库中定义的函数,用T表示,这是最常见的;另外一种是所 谓的“弱态”符号,它们虽然在库中被定义,但是可能被其他库中的同名符号覆盖,用W表示。例如,假设开发者希望知道上文提到的hello库中是否引用了 printf():

    $nm libhello.so | grep printf U

    其中printf U表示符号printf被引用,但是并没有在函数内定义,由此可以推断,要正常使用hello库,必须有其它库支持,再使用ldd工具查看hello依赖于哪些库:

    $ldd hello
    libc.so.6=>/lib/libc.so.6(0x400la000)
    /lib/ld-linux.so.2=>/lib/ld-linux.so.2 (0x40000000)

    从上面的结果可以继续查看printf最终在哪里被定义,有兴趣可以go on

    4、生成库

    第一步要把源代码编绎成目标代码。以下面的代码为例,生成上面用到的hello库:

    /* hello.c */
    #include "hello.h"
    void sayhello()
    {
        printf("hello,world ");
    }

    用gcc编绎该文件,在编绎时可以使用任何合法的编绎参数,例如-g加入调试代码等:

    $gcc -c hello.c -o hello.o

    1.连接成静态库 连接成静态库使用ar工具,其实ar是archive的意思

    $ar cqs libhello.a hello.o

    2.连接成动态库 生成动态库用gcc来完成,由于可能存在多个版本,因此通常指定版本号:

    $gcc -shared -Wl,-soname,libhello.so.1 -o libhello.so.1.0 hello.o

    另外再建立两个符号连接:

    $ln -s libhello.so.1.0 libhello.so.1
    $ln -s libhello.so.1 libhello.so

    这样一个libhello的动态连接库就生成了。最重要的是传gcc -shared 参数使其生成是动态库而不是普通执行程序。 -Wl 表示后面的参数也就是-soname,libhello.so.1直接传给连接器ld进行处理。实际上,每一个库都有一个soname,当连接器发现它正 在查找的程序库中有这样一个名称,连接器便会将soname嵌入连结中的二进制文件内,而不是它正在运行的实际文件名,在程序执行期间,程序会查找拥有 soname名字的文件,而不是库的文件名,换句话说,soname是库的区分标志。这样做的目的主要是允许系统中多个版本的库文件共存,习惯上在命名库 文件的时候通常与soname相同 libxxxx.so.major.minor 其中,xxxx是库的名字,major是主版本号,minor 是次版本号

    总结

    通过对LINUX库工作的分析,我们已经可以理解程序运行时如何去别的地方寻找“库”。

    附上针对这个工程的Makefile:

    # xiejingquan@gmail.com
    # export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:~/C/lib
    
    BIN_DIR=bin
    LIB_DIR=lib
    INC_DIR=inc
    SRC_DIR=src
    
    BIN=${BIN_DIR}/testlib
    LIB=${LIB_DIR}/libhello.a ${LIB_DIR}/libhello.so
    
    CC=gcc
    AR=ar
    DOC=doxygen
    
    CFLAGS=-g -Wall -c -Iinc
    LFLAGS=-lhello -L${LIB_DIR} -o
    ARFLAGS=cqs
    SOFLAGS=-shared -Wl,-soname,
    
    all: ${BIN}
    
    lib: ${LIB}
    
    run: all
    @./bin/testlib
    
    clean:
    rm -f ${BIN_DIR}/* ${LIB_DIR}/*
    
    ${BIN_DIR}/testlib: ${LIB_DIR}/testlib.o ${LIB}
    ${CC} $< ${LFLAGS} $@
    
    ${LIB_DIR}/testlib.o: ${SRC_DIR}/testlib.c ${INC_DIR}/hello.h
    ${CC} ${CFLAGS} $< -o $@
    
    ${LIB_DIR}/libhello.a: ${LIB_DIR}/hello.o
    ${AR} ${ARFLAGS} $@ $<
    
    ${LIB_DIR}/libhello.so: ${LIB_DIR}/hello.o
    ${CC} ${SOFLAGS}libhello.so.1 -o ${LIB_DIR}/libhello.so.1.0 ${LIB_DIR}/hello.o
    ln -s ${LIB_DIR}/libhello.so.1.0 ${LIB_DIR}/libhello.so.1
    ln -s ${LIB_DIR}/libhello.so.1 ${LIB_DIR}/libhello.so
    
    ${LIB_DIR}/hello.o: ${SRC_DIR}/hello.c ${INC_DIR}/hello.h
    ${CC} ${CFLAGS} $< -o $@

    附上文件的目录结构:

    |– bin
    | `– testlib
    |– doc
    |– inc
    | `– hello.h
    |– lib
    | |– hello.o
    | |– libhello.a
    | |– libhello.so -> lib/libhello.so.1
    | |̵

        
    最新技术文章:
     




    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3