Linux环境下动态连接库的生成和使用

使用本身封装的so时遇到了点问题,本着简便原则决定写个demo看看,顺便记录下整个过程。测试

 

1)生成so所需的文件以下:blog

print.hio

#ifndef __print_h__
#define __print_h__

void print(void);

#endif

print.cpp编译

#include <stdio.h>
#include "print.h"

void print(void)
{
	printf("hello world.\n");
}

bye.hclass

#ifndef __bye_h__
#define __bye_h__

void bye(void);

#endif

bye.cpptest

#include <stdio.h>
#include "bye.h"

void bye(void)
{
	printf("bye bye.\n");
}

midd.hdemo

#ifndef __midd_h__
#define __midd_h__

class Middleware{
	public:
		Middleware();
		~Middleware();

		bool data(const char *p);
};
#endif

midd.cppdi

#include "print.h"
#include "bye.h"
#include "midd.h"
#include <stdio.h>

Middleware::Middleware()
{
	printf("Middleware::Middleware()\n");
}

Middleware::~Middleware()
{
	printf("Middleware::~Middleware()\n");
}

bool Middleware::data(const char *p)
{
	print();
	bye();

	return true;
}

  

2)编译过程文件

g++ -c -fPIC -shared bye.cppco

g++ -c -fPIC -shared print.cpp

g++ -c -fPIC -shared midd.cpp

 

3)连接过程

g++ -o test.so midd.o print.o bye.o -fPIC -shared

 

4)动态连接库的使用

如今写一个main.cpp来调用so,看看效果

main.cpp

#include "midd.h"
int main()
{
	Middleware middleware;
	middleware.data("xxx");

	return 0;
}

生成可执行文件:

g++ -o test main.cpp ./test.so

测试:

./test

Middleware::Middleware()
hello world.
bye bye.
Middleware::~Middleware()
相关文章
相关标签/搜索