日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

mysql_real_connect阻塞_mysql_real_connect崩溃、未经处理的异常

發布時間:2025/3/15 数据库 16 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mysql_real_connect阻塞_mysql_real_connect崩溃、未经处理的异常 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

mysql_real_connect崩潰、未經處理的異常

背景

近期客戶測試軟件,功能里有mysql連接問題,在mysql連接失敗時,客戶機器上出現“已停止工作”界面,而我機器上軟件直接退出沒有提示自動關閉。

查找分析

因為是一直用的代碼,和網上代碼對比mysql_real_connect也用法一樣,想不到哪里錯誤,就先加上mysql的option處理代碼,類似如下。

unsigned int timeout = 5;

int ret = mysql_options(_connectionHandlerPtr, MYSQL_OPT_CONNECT_TIMEOUT, (const char *)&timeout);

if (ret) {

throw DataBaseError("mysql參數設置失敗");

return;

}

if (NULL == mysql_real_connect(_connectionHandlerPtr, server.c_str(), user.c_str(), password.c_str(), database.c_str(), import, NULL, 0))

{

throw DataBaseError("連接數據庫失敗");

return;

}

char value = 1;

mysql_options(_connectionHandlerPtr, MYSQL_OPT_RECONNECT, &value);

加了還是不行,不過用代碼調試運行報“未經處理的異常”,就查try,catch代碼,把catch里括號里參數類型里*去掉,“未經處理的異常”不報了,mysql_real_connect也不崩潰了。

未經處理的異常

從msdn里查下try catch的描述。

try {

// code that could throw an exception

}

[ catch (exception-declaration) {

// code that executes when exception-declaration is thrown

// in the try block

}

[catch (exception-declaration) {

// code that handles another exception type

} ] . . . ]

// The following syntax shows a throw expression:

throw [expression]

exception-declaration不是無變化的意思,它是和throw的值類型有關的,如果throw "abc",則catch里可以帶*號是char*,如果throw CXXError,就要catch(CXXError e),拋出什么類型就要catch什么類型,如果類型不一致,則會報“未經處理的異常”。

mysql_real_connect崩潰

mysql_real_connect連接失敗是會正常上報,代碼對應處理時會throw,是throw的問題,mysql_real_connect沒有問題。

總結

以上是生活随笔為你收集整理的mysql_real_connect阻塞_mysql_real_connect崩溃、未经处理的异常的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。