std::string strip
时间: 2023-11-06 14:07:57 浏览: 166
std::string是C++中的一个类,用于表示字符串。它包含在<string>头文件中,使用using namespace std;或者using std::string;进行命名空间引入。在UNICODE中,可以使用std::wstring将CString转换为std::string。
要截取一个字符串的子串,可以使用substr()函数。例如,如果原始字符串是s,要截取的子串是sub,可以使用以下代码:
sub = s.substr(startIndex, length);
其中startIndex是子串的起始位置,length是子串的长度。
另外,如果你想交换两个字符串的内容,可以使用swap()函数。例如,如果有两个字符串s1和s2,你可以使用以下代码交换它们的内容:
std::swap(s1, s2);
相关问题
CTcpServer::CTcpServer(std::string strIp, unsigned int uPort)
CTcpServer::CTcpServer(std::string strIp, unsigned int uPort)是一个构造函数,用于创建一个TCP服务器对象。该函数接受一个IP地址和一个端口号作为参数,并根据这些参数创建一个TCP套接字。
在函数内部,使用bind函数将监听套接字与指定的IP地址和端口号进行绑定。bind函数的第一个参数是监听套接字,第二个参数是一个指向sockaddr结构体的指针,其中包含了IP地址和端口号的信息。bind函数用于将套接字与指定的IP地址和端口号进行绑定,以便监听来自该地址和端口的连接请求。
接下来,使用listen函数开始监听套接字上的连接请求。listen函数的第一个参数是监听套接字,第二个参数是指定在连接队列中可以排队的最大连接数。一旦有连接请求到达,服务器将从连接队列中提取第一个连接,然后返回一个新的套接字,通过这个新套接字可以与客户端进行通信。
CTcpServer::CTcpServer函数还可以实现数据的收发功能。使用recv函数从客户端接收数据,recv函数的第一个参数是客户端套接字,第二个参数是接收数据的缓冲区,第三个参数是缓冲区的长度。如果没有可用的传入数据,recv函数将阻塞并等待数据的到来。一旦接收到数据,recv函数将返回接收到的字节数,并将数据保存在缓冲区中。
使用send函数向客户端发送数据,send函数的第一个参数是客户端套接字,第二个参数是要发送的数据的指针,第三个参数是要发送的数据的长度。send函数将数据从发送缓冲区复制到TCP输出队列中,并立即返回。
代码优化下面的代码:DWORD WINAPI SoapServerThread( LPVOID pParam ) { CUserManagerServerDlg *pUserManServer = (CUserManagerServerDlg *)pParam; struct soap Soap_service; soap_init(&Soap_service); Soap_service.pUserManagerServerDlg = pUserManServer; Soap_service.bind_flags = SO_REUSEADDR; USES_CONVERSION; std::string strIP(W2A(pUserManServer->m_csIP)); const char* chIP = strIP.c_str(); CString csInfo; int nBindErr; if ((nBindErr = soap_bind(&Soap_service,chIP, pUserManServer->m_nPort, 100))< 0) //soap_bind(&math_service, address, port, 100); { soap_print_fault(&Soap_service, stderr); //csInfo.Format(_T("用户服务器绑定失败")); csInfo.LoadString(IDS_BIND_FAILD); pUserManServer->RecordOperaInfo(csInfo,6); pUserManServer->RecordSQL(csInfo,6); return -1; } if (pUserManServer->m_csIP.IsEmpty() || !pUserManServer->m_nPort) { //csInfo.Format(_T("IP和端口号不允许为空!")); csInfo.LoadString(IDS_CANNOT_EMPTY); pUserManServer->RecordOperaInfo(csInfo,6); pUserManServer->RecordSQL(csInfo,6); return -1; } //csInfo.Format(_T("用户服务器已启动...")); csInfo.LoadString(IDS_STARTED); pUserManServer->RecordOperaInfo(csInfo,0); pUserManServer->RecordSQL(csInfo,0); CString csListen; csListen.LoadString(IDS_LISTEN); csInfo.Format(_T("%s:IP(%s),Port:(%d)"),csListen,pUserManServer->m_csIP,pUserManServer->m_nPort); pUserManServer->RecordOperaInfo(csInfo,0); pUserManServer->RecordSQL(csInfo,0); while (true) { int nSlave = (int)soap_accept(&Soap_service); if (nSlave < 0) { //csInfo.Format(_T("soap_accept调用失败...")); csInfo.LoadString(IDS_CALL_FAILD); pUserManServer->RecordOperaInfo(csInfo,6); pUserManServer->RecordSQL(csInfo,6); soap_print_fault(&Soap_service, stderr); return -1; } soap_serve(&Soap_service); soap_destroy(&Soap_service); soap_end(&Soap_service); } return 0; }
以下是对代码进行的优化:
1. 声明变量时最好直接初始化,避免未初始化的变量被使用。
2. 将字符串转换为const char*时,可以直接使用CString的GetString()函数。
3. 在循环中调用soap_destroy和soap_end函数是不必要的,只需要在循环之前调用一次即可。
4. 将错误码与字符串绑定在一起,可以减少代码量。
5. 将常量字符串存储在全局变量中,避免重复加载。
6. 可以尝试将一些重复的代码封装为函数,提高代码的复用性。
优化后的代码如下所示:
```
DWORD WINAPI SoapServerThread(LPVOID pParam) {
CUserManagerServerDlg* pUserManServer = static_cast<CUserManagerServerDlg*>(pParam);
struct soap Soap_service;
soap_init(&Soap_service);
Soap_service.pUserManagerServerDlg = pUserManServer;
Soap_service.bind_flags = SO_REUSEADDR;
const char* chIP = CStringA(pUserManServer->m_csIP.GetString());
static const int BIND_FAILD = 6;
static const int CALL_FAILD = 6;
static const int INFO = 0;
static const CStringA STR_BIND_FAILD("用户服务器绑定失败");
static const CStringA STR_CANNOT_EMPTY("IP和端口号不允许为空!");
static const CStringA STR_STARTED("用户服务器已启动...");
static const CStringA STR_LISTEN("监听");
if (pUserManServer->m_csIP.IsEmpty() || !pUserManServer->m_nPort) {
pUserManServer->RecordOperaInfo(STR_CANNOT_EMPTY, BIND_FAILD);
pUserManServer->RecordSQL(STR_CANNOT_EMPTY, BIND_FAILD);
return -1;
}
CStringA strInfo;
strInfo.Format("%s:IP(%s),Port:(%d)", STR_LISTEN.GetString(), chIP, pUserManServer->m_nPort);
pUserManServer->RecordOperaInfo(CString(strInfo), INFO);
pUserManServer->RecordSQL(CString(strInfo), INFO);
int nBindErr;
if ((nBindErr = soap_bind(&Soap_service, chIP, pUserManServer->m_nPort, 100)) < 0) {
strInfo = STR_BIND_FAILD;
pUserManServer->RecordOperaInfo(CString(strInfo), BIND_FAILD);
pUserManServer->RecordSQL(CString(strInfo), BIND_FAILD);
soap_print_fault(&Soap_service, stderr);
return -1;
}
strInfo = STR_STARTED;
pUserManServer->RecordOperaInfo(CString(strInfo), INFO);
pUserManServer->RecordSQL(CString(strInfo), INFO);
while (true) {
int nSlave = (int)soap_accept(&Soap_service);
if (nSlave < 0) {
strInfo = STR_CALL_FAILD;
pUserManServer->RecordOperaInfo(CString(strInfo), CALL_FAILD);
pUserManServer->RecordSQL(CString(strInfo), CALL_FAILD);
soap_print_fault(&Soap_service, stderr);
return -1;
}
soap_serve(&Soap_service);
}
soap_destroy(&Soap_service);
soap_end(&Soap_service);
return 0;
}
```
阅读全文