Qpid第三課 qpid-cpp編譯
一般情況下,在qpid-cpp-1.36.0目錄下創建build文件夾應用於VS解決方案生成
CMake配置如下:
Where is the source code:E:/bin/qpid-cpp-1.36.0
Where is build the binaries:E:/bin/qpid-cpp-1.36.0/build
BUILD_BINDING_DOTNET 取消編譯
CMake點擊Configure檢測系統是否安裝必須的依賴庫,點擊Generate生成VS2015解決方案,在
build目錄下生成qpid-cpp.sln,當前編譯Qpid的核心原因是Qpid Client客戶端調用的DLL,出現
內存泄露,因此只需要打開examples文件夾下面的qpidc_examples.sln,進行代碼的跟蹤調試
qpidc_exmaples.sln配置,設置client作為啟動項,
將boost庫的DLL,qpidclientd.dll qpidcommond.dll qpidmessagingd.dll qpidtyped.dll
拷貝到examples\messaging\Debug
編寫簡單的測試程序:
int SimpleTest()
{
std::string broker = "localhost:5672";
std::string address = "amq.topic";
Connection connection(broker);
try {
connection.open();
Session session = connection.createSession();
while (1)
{
Receiver &receiver = session.createReceiver(address);
Sender &sender = session.createSender(address);
sender.send(Message("Hello world!"));
Message message = receiver.fetch(Duration::SECOND * 1);
std::cout << message.getContent() << std::endl;
session.acknowledge();
::Sleep(25);
}
session.close();
connection.close();
return -1;
}
catch (const std::exception& error) {
std::cerr << error.what() << std::endl;
connection.close();
return 0;
}
}
int main(int argc, char** argv)
{
while (1)
{
SimpleTest();
::Sleep(25);
}
return 0;
}
總結
不斷的連接斷開將造成內存泄露,如果保持長連接,只是進行消息的收發,就不會出現內存問題
Qpid第三課 qpid-cpp編譯