今天在公司实习时遇上点小问题,具体不便多说,但是关于这个问题的解决办法在此还是想分享下。
很多人都知道,对string可以用c_str()函数将其转变为一个char数组的形式,但是在这之中,数组的首地址指针不能进行加减,如果在此时你想利用指针的思想遍历此string的每一个字符,这是非常头疼的(因为我需要遍历一个形似“12664 144848 2488 186 54”的string,将其分割成以空格为分割点的若干个字符串,并将其转换为int类型)下面我的代码便是实现这功能,并将其存入一个vector中:
#include <iostream>
#include <vector>
#include <string>
using namespace std;
//此函数实现返回字符串str子串的个数
//int NumCount(char *str)
int NumCount(string str)
{
int count = 0;
//!此为网上找了很多没用的回答后找到的,通过
//定义一个指向字符串首地址的指针,来对str实现指针后移操作
char* temp=&str[0];
while (*temp != '\0')
{
if (' ' == *temp)
{
count++;
}
temp++;
}
return count + 1;
}
//void GetArr(vector<int > &arr,char* str,const int count)
//此为将字符串转换为子串的接口,具体实现不再注释,希望自己看懂
void GetArr(vector<int > &arr, string str, const int count)
{
char buf[100];
memset(buf, '\0', 100);
//类似上述方法
char* temp1 = &str[0];
char* temp2 = buf;
for (int i = 0; i < count; i++)
{
temp2 = buf;
while (*temp1 != ' '&&*temp1 != '\0')
{
*temp2 = *temp1;
temp1++;
temp2++;
}
temp1++;
arr.push_back(atoi(buf));
//cout << arr[1] << endl;
memset(buf, '\0', 100);
}
}
int main()
{
//char str[] = "15469 59958 65486 97445";
string str= "15469 59958 65486 97445";
vector<int > arr;
int count = NumCount(str);
cout << count << endl;
GetArr(arr,str,count);
for (vector<int >::iterator ite = arr.begin(); ite != arr.end(); ite++)
cout << *ite << " ";
cout << "Hello" << endl;
system("pause");
}
上述代码段中我将改进前的代码进行了行注释,由于char* 型变量作为形参在某些情况下会出现问题(我师傅告诉我的,具体原因没追问,可能他只是想让我用c++风格儿而不是c风格的指针吧)故需要将之前的char全变为string型,这就导致了我先前写的指针方法难以实现,故找出了 char temp=&str[0]这一神级解决办法。完美将string的问题转换到了熟悉的解决方式上。
另外提一点,在找到这方法前我曾试过用迭代器来模拟指针,将迭代器哦初始化为str.begin(),不过在*ite(ite为迭代器)时发生了问题,后来网上查阅资料得知,迭代器实际为一个类,只是它模拟了指针,使得它看起来很像指针而已。关于这一点我也确实发现了自己想法的漏洞,将在之后的学习中补足。
经过这次的摸索后我也意识到了c和c++思想的一点不同之处,比如在嵌入式开发中,浓烈的c风格使得传地址,指针作形参非常常见,但是在系统开发中,c++拥有各种好用的stl库,再加上引用对指针的代替作用,使得在接口的编写中,指针变量作参数变的非常别扭,而这些通过引用将完美替代。 而且stl使得不必担心越界的问题,当然这已经时老生长谈了,在此也是忍不住感慨下。