序列化后發(fā)送
main.cpp:
#include <iostream>
#include "libUO.h"
int main()
{
UO_C_Socket t;
// t.StartSocketServer("",4121);
boost::thread t1(boost::bind(&UO_C_Socket::StartSocketServer,&t,"",4121));
sleep(2);
// boost::thread t2(boost::bind(&UO_C_Socket::StartSocketClient,&t,"127.0.0.1",4121));
// t2.join();
t1.join();
return 0;
}
客戶端
客戶端在UO_BaseFun.h里實現(xiàn)基本功能,將其進行封裝并通過boost_python導出。特別注意,這里BOOST_PYTHON_MODULE中的名字需和最后make出的so文件
同名,不然會出現(xiàn)錯誤,錯誤名字忘記了
UO_libdll_py_wrap.cpp:
#include <boost/python.hpp>
#include <boost/python/module.hpp>
#include <boost/python/def.hpp>
#include "UO_BaseFun.h"
BOOST_PYTHON_MODULE(UO_BaseFun) //python模塊
{
// boost::python::class_<UO_C_Socket,boost::noncopyable>("UO_C_Socket")
boost::python::class_<UO_C_Socket>("UO_C_Socket")
.def("StartSocketClient",&UO_C_Socket::StartSocketClient)
// .def("getname",&student::getname)
// .def("setage",&student::setage)
// .def("getage",&student::getage)
// .add_property("name",&student::getname,&student::setname)
// .add_property("age",&student::getage,&student::setage)
;
}
特別注意的是makefile中編譯和連接的區(qū)別,其中出現(xiàn)的未定義符號錯誤需加上動態(tài)鏈接庫-lboost_filesystem等。出現(xiàn)找不到pyconfig.h錯誤需包含
-I/usr/include/python2.7。make完了之后生成UO_BaseFun.so文件
makefile:
UO_BaseFun.so:UO_libdll_py_wrap.o g++ UO_libdll_py_wrap.o -o UO_BaseFun.so -shared -fPIC -L/usr/lib/x86_64-linux-gnu\ -lboost_filesystem -lboost_thread -lboost_serialization -lboost_python -lboost_system UO_STR.o: g++ -c UO_STR.h -o UO_STR.o -I/usr/include/boost \ # -lboost_serialization UO_BaseFun.o:UO_STR.o g++ -c UO_BaseFun.h -o UO_BaseFun.o -I/usr/include/boost \ # -lboost_system -lboost_filesystem -lboost_thread -lboost_serialization UO_libdll_py_wrap.o:UO_BaseFun.o g++ -c UO_libdll_py_wrap.cpp -o UO_libdll_py_wrap.o -fPIC -I/usr/include/python2.7 # -lboost_serialization clean: rm -rf UO_STR.o O_libdll_py_wrap.o UO_BaseFun.o rm -rf UO_BaseFun.so
驗證
UO_StoreSystem_py.py:
import UO_BaseFun
test = UO_BaseFun.UO_C_Socket()
test.StartSocketClient("127.0.0.1",4121)