总结所有遇到的C++常用技巧

版权声明:转载请注明出处 https://blog.csdn.net/weixin_39540568/article/details/87687918

=================20180708======================

////////////////////C++中分割string字符串    substr方法////////////////////////////////

vector<string> gethalfstringvector(string inputString)
{
vector<string> outvector;
string first = inputString.substr(0, inputString.size() / 2);
outvector.push_back(first);
string second = inputString.substr(inputString.size()/2,inputString.size());
outvector.push_back(second);
return outvector;
}

////////////////////C++中去除vector中重复元素方法////////////////////////////////

sort(outvector.begin(), outvector.end());
outvector.erase(unique(outvector.begin(),outvector.end()),outvector.end());

说明:sort完成vector中元素排序,unique将遍历所给区间内的元素,将重复的元素移到末尾,并返回末尾重复元素的地址,最后通过erase进行删除

包含头文件:#include <algorithm>

/////////////////////C++ map的相关操作///////////////////////////////////////////////

if(m.count(key)>0)
{
    return m[key];
}
return null;
1 iter = m.find(key);
2 if(iter!=m.end())
3 {
4 return iter->second;
5 }
6 return null;

m.insert(make_pair(n,m));

其中:make_pair需要包含#include <utility>

/////////////////////////////C++ 中文件操作//////////////////////////////////////////

ifstream filestream;
filebuf *pbuf;
char *buffer;
long size;
filestream.open((const char*)m_sSelectFilePath.toStdString().c_str(),ios::binary);
if (filestream.is_open())
{
pbuf = filestream.rdbuf();
size = pbuf->pubseekoff(0,ios::end,ios::in);
//qDebug()<<size;
pbuf->pubseekpos(0,ios::in);
buffer = new char[size];
pbuf->sgetn(buffer,size);
m_bPDSpectraFileData.clear();
for (int loop =0;loop <size;loop++)
{
m_bPDSpectraFileData.append(buffer[loop]);
}
delete[] buffer;
filestream.close();
}
else
{
QMessageBox::information(NULL,"Waring","所选文件不存在或已被删除,请检查!");
}

/////////////////////////////C 中创建多级目录//////////////////////////////////////////

/**
* @brief mkdirs C语言创建多级目录
* @add by yuansong 20181204
* @param muldir
*/
ST_RET mkdirs(char *muldir)
{
    int i,len;
    char str[512];
    strncpy(str, muldir, 512);
    len=strlen(str);
    for( i=0; i<len; i++ )
    {
        if( str[i]=='/' && i != 0)      //增加i!=0 考虑的是linux目录构建首字符为/
        {
            str[i] = '\0';
            if( access(str,0)!=0 )
            {
                if(0!=mkdir( str, 0777 ))
                    return SD_FAILURE;
            }
            str[i]='/';
        }
    }
    if( len>0 && access(str,0)!=0 )
    {
       if(0 != mkdir( str, 0777 ))
           return SD_FAILURE;
    }
    return SD_SUCCESS;
}

猜你喜欢

转载自blog.csdn.net/weixin_39540568/article/details/87687918