如何用gcc/g++编译生成so链接库,以及how to use .so
2014-01-14 18:10
369 查看
(3年前) 由于以后要开发一个mysql的.so,所以该事例名字为my,类名为mysql。
为了说的更明白,mysql里面有3种成员函数,int , unsigned int, char *, 每个成员函数的初始化以及获取都是在一个链接库里面(懒得写set function)。
文件: foo.h num.cpp size.cpp name.cpp main.cpp
num.cpp
size.cpp
name.cpp
main.cpp
说明
-fPIC:表示编译为位置独立的代码,不用此选项的话编译后的代码是位置相关的所以动态载入时是通过代码拷贝的方式来满足不同进程的需要,而不能达到真正代码段共享的目的。
-L.:表示要连接的库在当前目录中
-lxxx:编译器查找动态连接库时有隐含的命名规则,即在给出的名字前面加上lib,后面加上.so来确定库的名称libxxx.so
加上 export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:. 然后执行ldd
然后运行./main,终于出现结果了
为了说的更明白,mysql里面有3种成员函数,int , unsigned int, char *, 每个成员函数的初始化以及获取都是在一个链接库里面(懒得写set function)。
说明:
文件目录:my文件: foo.h num.cpp size.cpp name.cpp main.cpp
准备文件:
foo.h#ifndef _MY_FOO_H #define _MY_FOO_H #define u_int unsigned int #include<malloc.h> class mysql { public : char *file_name; u_int file_size; int num; public : void init_size(u_int size); u_int get_size(); char *get_name(); void init_name(char* name); void init_num(int n); int get_num(); void add(int n); void del(int n); ~mysql() { free(file_name); } };
num.cpp
#include"foo.h" #include<iostream> using namespace std; void mysql::init_num(int n) { this->num = n; } int mysql::get_num() { return this->num; }
size.cpp
#include"foo.h" void mysql::init_size(u_int size) { this->file_size = size; } u_int mysql::get_size() { return this->file_size; }
name.cpp
#include"foo.h" #include<stdio.h> #include<string.h> #include<malloc.h> void mysql::init_name(char * name) { if( ( sizeof(name) + 1 ) > this->file_size) { printf("the length of name is too long\n"); return ; } this->file_name = (char *)calloc(1,sizeof(name)+1); strcpy(this->file_name, name); } char* mysql::get_name() { return this->file_name; }
main.cpp
#include"foo.h" #include<iostream> using namespace std; int main() { mysql *my = new mysql(); my->init_num(4); int num = my->get_num(); cout << "num is " << num << endl; my->init_size(100); u_int size = my->get_size(); cout << "file_size is " << size << endl; my->init_name( (char*)("MYSQL") ); cout << my->get_name() << endl; return 0; }
编译生成so文件:
libnum.so $ g++ num.cpp -fPIC -shared -o libnum.so libsize.so $ g++ size.cpp -fPIC -shared -o libsize.so libname.so $ g++ name.cpp -fPIC -shared -o libname.so $ ls
说明
-fPIC:表示编译为位置独立的代码,不用此选项的话编译后的代码是位置相关的所以动态载入时是通过代码拷贝的方式来满足不同进程的需要,而不能达到真正代码段共享的目的。
-L.:表示要连接的库在当前目录中
-lxxx:编译器查找动态连接库时有隐含的命名规则,即在给出的名字前面加上lib,后面加上.so来确定库的名称libxxx.so
生成可执行文件
$ g++ main.cpp -L. -lnum -lname -lsize -o main然后就有可执行文件,但是好像不给力,没法运行。因为没有修改,LD_LIBRARY_PATH,这个环境变量指示动态连接器可以装载动态库的路径。加上 export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:. 然后执行ldd
然后运行./main,终于出现结果了
相关文章推荐
- Spring MVC 关于中文显示异常的注意事项
- 阶乘的精确值
- Ubuntu apache 禁止目录浏览
- mysql的SUBSTRING_INDEX 的使用
- Oracle数据库之PLSQL集合
- SGU 141 Jumping Joe(扩展欧几里得)
- 开发备忘录
- CImage类库
- Opencv cvAbs函数
- LVM逻辑卷管理器
- Opencv cvAbs函数
- C++编程思想笔记
- ios_oc学习总结
- TSQL--NULL值和三值逻辑
- Cximage 切图部分代码mark
- Linux文件系统-3个重要数据结构及相互间的关系
- mysql cluster 节点增加和减少
- POJ - 1101 The Game DFS
- Android framwork cpp调用java function
- rhel 6.3 建立centos yum