Mysql以及TCP socket的C++代码
在使用socket编写tcp的C++程序时,遇到了一个问题:
那就bind冲突了,分析原因:是因为std中有bind函数,而socket中也有,但是没有报重复定义的错误,这就有一点难办了。
百度了一下:发现只要使用::bind就可以调用socket的bind。
下面把这个套接字socket的server端代码贴出来:
static void* serverThread(void* pointer) { ofstream log("connect.txt", std::ios::app); pthread_setcancelstate(PTHREAD_CANCEL_ENABLE, NULL); pthread_setcanceltype(PTHREAD_CANCEL_ASYNCHRONOUS, NULL); CarDetect* p_car = (CarDetect*)pointer; WSADATA wsdata; if (WSAStartup(MAKEWORD(2, 2), &wsdata)) { log << "WAS failed" << endl; WSACleanup(); return FALSE; } SOCKET s_server, s_accept; s_server = socket(PF_INET, SOCK_STREAM, 0); if (s_server == INVALID_SOCKET) { log << "socket failed" << endl; WSACleanup(); return FALSE; } //填充服务端信息 SOCKADDR_IN server_addr; server_addr.sin_family = AF_INET; server_addr.sin_port = htons(8226); //当然这里也可以将 127.0.0.1改成你想要的ip或者 INADDR_ANY 为向所有ip发送信息 server_addr.sin_addr.S_un.S_addr = inet_addr("127.0.0.1"); //数据绑定服务器 s_server为服务端套接字 if (::bind(s_server, (SOCKADDR*)&server_addr, sizeof(SOCKADDR)) == SOCKET_ERROR) { log << "listen failed" << endl; WSACleanup(); return FALSE; } if (listen(s_server, 1) == SOCKET_ERROR) { log << "listen failed" << endl; WSACleanup(); return FALSE; } sockaddr_in accept_addr; //用来记录请求连接的套接字信息 int len = sizeof(SOCKADDR); char recv_buf[8192] = { 0 }; char send_buf[1024] = { 0 }; while (true) { //接受连接请求 s_accept = accept(s_server, (SOCKADDR*)&accept_addr, &len); while (true) { pthread_testcancel(); int count = p_car->count; snprintf(send_buf, sizeof(send_buf), "%s", to_string(count).c_str()); int sendLen = send(s_accept, (char*)send_buf, sizeof(send_buf), 0); if (sendLen < 0) { log << "send failed" << endl; break; } Sleep(2500); } } }
Mysql的线程也贴一下,注意这个mysql的C++库可以在官网下载:
static void* sqlThread(void* pointer) { ofstream log("sql.txt", std::ios::app); pthread_setcancelstate(PTHREAD_CANCEL_ENABLE, NULL); pthread_setcanceltype(PTHREAD_CANCEL_ASYNCHRONOUS, NULL); CarDetect* p_car = (CarDetect*)pointer; mysql_init(&p_car->mysql); //连接mysql,数据库 //中间分别是主机,用户名,密码,数据库名,端口号(可以写默认0或者3306等),可以先写成参数再传进去 const char DataBase_UserName[] = "root"; //数据库用户名username const char DataBase_Password[] = "a1234567"; //数据库密码 const char DataBase_Host[] = "localhost"; //数据库连接地址 const char DataBase_Name[] = "mysql"; //database name unsigned int DataBase_Port = 3306; //server port if (!(mysql_real_connect(&p_car->mysql, DataBase_Host, DataBase_UserName, DataBase_Password, DataBase_Name, DataBase_Port, NULL, DataBase_Port))) { //TRACE1("Error connecting to database: %s\n", mysql_error(&mysql)); log << "connect failed" << endl; return false; } while (true) { pthread_testcancel(); //string sql_select="SELECT count FROM carcount"; //vector<vector<wchar_t*>> res=selectData(p_car->mysql,sql_select); /*for (int i = 0; i < res.size(); i++) { for (int j = 0; j < res[i].size(); j++) { log << res[i][j] << endl; } }*/ //log << _wtoi(res[0][0]) << endl; string sql_update = "UPDATE carcount SET count = " + to_string(p_car->count) + ";"; int ret = mysql_query(&p_car->mysql, sql_update.c_str()); if (ret) { log << "update failed" << endl; } Sleep(5000); } }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理