版权声明:转载请注明出处 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","所选文件不存在或已被删除,请检查!");
}
扫描二维码关注公众号,回复:
5289109 查看本文章
/////////////////////////////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;
}