1.首先看文件形式
其中cpp1是直接调用.cpp和生成.so的文件夹。
cpp2是测试生成的.so可以使用的文件夹。
2.先直接编译.cpp检查代码没问题
a.cpp内容:
#include <iostream>
#include "a.h"void A::readImg(char* path)
{B b;b.readImg(path);}
a.h内容:
#ifndef A_H_
#define A_H_#include "b.h"class A
{public:A(){}~A(){}void readImg(char* path);};#endif
b.cpp内容:
#include "b.h"void B::readImg(char* path)
{cv::Mat img = cv::imread(path);std::cout<<"图像宽为:"<<img.cols<<"\t高度为:"<<img.rows<<"\t通道数为:"<<img.channels()<<std::endl;
}
b.h内容
#ifndef B_H_
#define B_H_#include <opencv2/opencv.hpp>
class B
{public:void readImg(char* path);
};#endif
main.cpp内容
//main.cpp
#include "a.h"int main()
{char *path =(char*) "test.jpg";A a;a.readImg(path);return 0;
}
CMakeLists.txt内容:
cmake_minimum_required(VERSION 2.6)project(cpp1)add_definitions(-std=c++11)set(CMAKE_CXX_STANDARD 11)
set(CMAKE_BUILD_TYPE Debug)find_package(OpenCV REQUIRED)
include_directories(OpenCV_INCLUDE_DIRS)add_executable(main ${PROJECT_SOURCE_DIR}/main.cpp a.cpp b.cpp)
target_link_libraries(main ${OpenCV_LIBS})add_definitions(-O2 -pthread)
make以后生成可执行文件main,可打印如下信息,说明整个代码都是没问题的。
执行./main
3.在cpp2调用.so文件
首先在cpp1下生成.so文件(注意.so文件要以lib开头,在使用的时候要把lib去掉)
g++ -fpic -shared -o libCPP1.so a.cpp b.cpp -I /usr/local/include -L /usr/local/lib -lopencv_core -lopencv_highgui
生成libCPP1.so文件。
新建cpp2文件夹,将cpp1的main.cpp, .h文件和libCPP1.so拷贝进来。
第一种执行方式:
g++ -o ./main -std=c++11 main.cpp -L ./ -lCPP1
即可生成可执行文件main,打印一下,发现结果一样,说明生成的.so文件成功.
执行./main
第二种执行方式:
CMakeLists.txt内容: 将生成的.so路径作为可链接库
cmake_minimum_required(VERSION 2.6)project(cpp2)add_definitions(-std=c++11)set(CMAKE_CXX_STANDARD 11)
set(CMAKE_BUILD_TYPE Debug)# find_package(OpenCV REQUIRED)
# include_directories(OpenCV_INCLUDE_DIRS)add_executable(main ${PROJECT_SOURCE_DIR}/main.cpp)
# target_link_libraries(main ${OpenCV_LIBS})
target_link_libraries(main ${OpenCV_LIBS} /home/fzh/AI/learn_cplus/learn_some_api/cpp2/libCPP1.so)
add_definitions(-O2 -pthread)
cmake以后在make生成可执行文件main,说明编译成功。
执行./main