深入學習makefile,用makefile編譯動態庫

Lunix下生成動態庫文件:

         之前已經介紹了.o,.a,.so文件類型的含義,.so後綴的文件是動態庫文件。

        下面介紹在編譯過程中鏈接到動態庫文件的方法:

一.   源碼文件:

so_test.h:

void test_a();

void test_b();

void test_c();

test_a.c:

#include "so_test.h"

void test_a()

{

    printf("this is in test_a...\n");

}

test_b.c:

#include "so_test.h"

void test_a()

{

    printf("this is in test_b...\n");

}

test_c.c:

#include "so_test.h"

void test_a()

{

    printf("this is in test_c...\n");

}

test.c:

#include "so_test.h"

int main()

{

test_a();

test_b();

test_c();

return 0;

}

二.Makefile文件:

#*****************************************************************************

# Copyright        : 

#

# Author           :   huochangjun

# Date             :   2012-08-16

# Version           :   Demo1 動態鏈接庫

# Description             :   Demo

#

#****************************************************************************/

SHELL = /bin/sh

LIB_DIR = /cbs/lhbb/hcj/dy2/lib/

BIN_DIR = /cbs/lhbb/hcj/dy2/bin/

OBJECT_DIR = /cbs/lhbb/dy2/test/obj/

APP_DIR = /cbs/lhbb/hcj/dy2/testapp/

$(shell mkdir -p ${LIB_DIR})

$(shell mkdir -p ${BIN_DIR})

$(shell mkdir -p ${OBJECT_DIR})

RM = rm -fr

#****************************************************************************

CC = gcc

SHARED = -shared -o

FPIC = -fPIC -c

SRC_OBJECT = $(APP_DIR)test_a.c $(APP_DIR)test_b.c $(APP_DIR)test_c.c

H_OBJECT = $(APP_DIR)so_test.h

OBJECT = test_a.o test_b.o test_c.o

DY_SRC_OBJECT = $(APP_DIR)test.c

DY_OBJECT=test.o

LIB_OBJECT = libtest.so

BIN_OBJECT = test

#****************************************************************************

.PHONY:all

all:$(LIB_OBJECT) $(BIN_OBJECT)

$(LIB_OBJECT):$(OBJECT)

        $(CC) $(OBJECT) $(SHARED) -fPIC -o $(LIB_OBJECT)

        mv $(LIB_OBJECT) $(LIB_DIR)

$(OBJECT):$(SRC_OBJECT) $(H_OBJECT)

        $(CC) $(FPIC) $(SRC_OBJECT)

$(BIN_OBJECT):$(DY_OBJECT)

        $(CC) $(OBJECT_DIR)$(DY_OBJECT) -L$(LIB_DIR) -ltest -o $(BIN_OBJECT)

        mv $(BIN_OBJECT) $(BIN_DIR)

$(DY_OBJECT):$(DY_SRC_OBJECT)

        $(CC) -c $(DY_SRC_OBJECT)

        mv $(OBJECT) $(DY_OBJECT) $(OBJECT_DIR)

clean:

        $(RM) $(LIB_DIR) $(BIN_DIR) $(OBJECT_DIR)

三.對makefile文件的簡單闡述:

基本的變量賦值在生成靜態庫文件已經介紹了,這邊就不再重複了。

和靜態庫文件的生成不同的是,編譯的命令不同:

1.$(CC) $(OBJECT) $(SHARED) -fPIC -o $(LIB_OBJECT)

----這邊$(SHARED)變量是:-shared –o 是編譯動態庫必須使用的;

  -fPIC 編譯位置獨立的代碼,任何位置可以使用,達到共享內存;

2. $(CC) $(OBJECT_DIR)$(DY_OBJECT) -L$(LIB_DIR) -ltest -o $(BIN_OBJECT)

---- -L$(LIB_DIR) –ltest:ltest是固定的,取生成的動態庫文件文件名去掉lib和後綴,然後加上l,這行命令就是在目錄下尋找動態庫文件,鏈接上動態庫文件;

四.查看可執行文件是否鏈接上動態庫文件:

執行make後,生成的目錄結構和靜態庫文件一樣,此時用命令ldd libtest.so查看是否鏈接上動態庫文件:

libtest.so =>not found:顯示這樣的結果說明可執行文件沒有鏈接上動態庫文件,現在有如下兩種方式去處理:

  1. 用root用戶登陸環境,進入etc目錄,在ld.so.conf文件後增加你要鏈接的路徑,然後執行ldconfig即可,這樣修改後,你目錄下的動態庫文件就是全局的,而非個人環境中的;
  2. 修改個人環境中的.cshrc文件,在文件中設定共享目錄:

  setenv LD_LIBRARY_PATH /cbs/lhbb/hcj/dy2/lib:${LIBPATH};

  這樣在每次登陸你的個人環境的時候,纔會將LD_LIBRARY_PATH重新賦值,影響的僅僅是你的個人環境;

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章