C++ 将逗号分隔的十六进制(字符串)数组转换为整数或浮点
阵列的设置如下所示:C++ 将逗号分隔的十六进制(字符串)数组转换为整数或浮点,c++,arrays,string,C++,Arrays,String,阵列的设置如下所示: string * str = new string[11]; 其中字符串的内容如下所示: str[0]=AAAAAAAA,BBBBBBBB,CCCCCCCC,DDDDDDDD,EEEE,FFFFFFFF,GGGGGGGG,HHHH,IIII,JJJJ,KKKK str[1]=AAAAAAAA,BBBBBBBB,CCCCCCCC,DDDDDDDD,EEEE,FFFFFFFF,GGGGGGGG,HHHH,IIII,JJJJ,KKKK str[2]=AAAAAAAA,BBBBB
string * str = new string[11];
其中字符串的内容如下所示:
str[0]=AAAAAAAA,BBBBBBBB,CCCCCCCC,DDDDDDDD,EEEE,FFFFFFFF,GGGGGGGG,HHHH,IIII,JJJJ,KKKK
str[1]=AAAAAAAA,BBBBBBBB,CCCCCCCC,DDDDDDDD,EEEE,FFFFFFFF,GGGGGGGG,HHHH,IIII,JJJJ,KKKK
str[2]=AAAAAAAA,BBBBBBBB,CCCCCCCC,DDDDDDDD,EEEE,FFFFFFFF,GGGGGGGG,HHHH,IIII,JJJJ,KKKK
...
str[12]=AAAAAAAA,BBBBBBBB,CCCCCCCC,DDDDDDDD,EEEE,FFFFFFFF,GGGGGGGG,HHHH,IIII,JJJJ,KKKK
string * type = new string[11];
另一个数组如下所示:
str[0]=AAAAAAAA,BBBBBBBB,CCCCCCCC,DDDDDDDD,EEEE,FFFFFFFF,GGGGGGGG,HHHH,IIII,JJJJ,KKKK
str[1]=AAAAAAAA,BBBBBBBB,CCCCCCCC,DDDDDDDD,EEEE,FFFFFFFF,GGGGGGGG,HHHH,IIII,JJJJ,KKKK
str[2]=AAAAAAAA,BBBBBBBB,CCCCCCCC,DDDDDDDD,EEEE,FFFFFFFF,GGGGGGGG,HHHH,IIII,JJJJ,KKKK
...
str[12]=AAAAAAAA,BBBBBBBB,CCCCCCCC,DDDDDDDD,EEEE,FFFFFFFF,GGGGGGGG,HHHH,IIII,JJJJ,KKKK
string * type = new string[11];
其中内容为:
type[0]="1";
type[1]="1";
type[2]="1";
type[3]="1";
type[4]="2";
type[5]="1";
type[6]="1";
type[7]="2";
type[8]="2";
type[9]="2";
type[10]="2";
这些类型对应于字符串中的每个值,因此,对于第一个字符串:
1=浮点,2=整数
- AAAAA将是1;或者是一个浮子
- BBBBBBBB将1;或者是一个浮子
- CCCC将是1;或者是一个浮子
- dddddd将是1;或者是一个浮子
- EEEE将是2;还是整数
- FFFFFFFF将为1;或者是一个浮子
- gggggggggggg将1;或者是一个浮子
- HHHH将是2;还是整数
- IIII将是2;还是整数
- JJJJ将是2;还是整数
- KKKK将是2;还是整数
unsigned int-BinaryParser::hexToFloat(std::string-hextinput)
{
std::stringstream ss(十六进制输入);
无符号整数浮点输出;
ss>>十六进制>>浮点输出;
返回重新解释(浮点输出);
}
好的,第一部分:提取逗号分隔的字符串。一种方法是:
std::vector<std::string> split( std::string s ){
std::vector<std::string> vec;
int pos = 0;
while( std::string::npos != (pos = s.find( ',', pos ) ) ){
vec.push_back( s.substr( 0, pos ) );
s = s.substr( pos + 1 );
}
vec.push_back( s );
return vec;
}
无法使用std::hex读取浮点,因此我们假设hh是浮点的字节,被解释为int32\t
float convFloat( std::string & hexInput ){
std::istringstream iss (hexInput);
uint32_t intOutput;
iss >> std::hex >> intOutput;
return reinterpret_cast<float&>(intOutput);
}
float-convFloat(标准::字符串和十六进制输入){
std::istringstream iss(hexInput);
uint32输入输出;
iss>>标准::十六进制>>输入输出;
返回重新解释(输入输出);
}
为了存储结果,我们可以使用:
enum TypeTag { eInt, eFloat };
class IntOrFloat {
public:
IntOrFloat( int i ) : typeTag(eInt),integer(i),floating(0) { }
IntOrFloat( float f ) : typeTag(eFloat),integer(0),floating(f) { }
virtual ~IntOrFloat(){}
int getInt() const { return integer; }
float getFloat() const { return floating; }
TypeTag getTypeTag() const { return typeTag; }
private:
TypeTag typeTag;
int integer;
float floating;
};
std::ostream& operator<< (std::ostream& os, const IntOrFloat& iof){
switch( iof.getTypeTag() ){
case eInt:
os << iof.getInt();
break;
case eFloat:
os << iof.getFloat();
break;
}
return os;
}
enum TypeTag{eInt,eFloat};
将类划分为类{
公众:
IntOrFloat(inti):类型标签(eInt),整数(i),浮点(0){
IntOrFloat(float f):类型标签(eFloat),整数(0),浮点(f){}
虚拟~IntOrFloat(){}
int getInt()常量{返回整数;}
float getFloat()常量{return floating;}
TypeTag getTypeTag()常量{return TypeTag;}
私人:
类型标签类型标签;
整数;
浮动;
};
std::ostream&operator大小为X的数组只能在0到X-1之间寻址。您所做的str和类型初始化都是无效的。这只是我输入的错误。抱歉,整数只有4个十六进制数字?不寻常。十六进制数字的顺序是小端还是大端?问题出在哪里?可以将十六进制数字对转换为字符值吗?可以将字符值存储到字符数组[2]或字符数组[4]中吗?您可以获取浮点或整数的地址?你可以叫memcpy吗?@laune你能给我举个例子吗。我对C++不太好,对我来说很陌生。好,跟我来。我对向量不太熟悉。这将分离每个单独的字符串,并将其放入向量中自己的索引中,对吗?如果是这样,那么它将无法处理字符串数组,而只能处理单个字符串。我是否需要创建多个向量来接收信息?是否有方法创建类似于二维阵列的二维向量?这样,所有数据都可以保存在一个向量中。函数不确定它们的结果存储在向量中的方式。如果十六进制字符串在11/12/13字符串中的原始位置无关紧要,您可以将它们全部归档到一个向量中。非常感谢!!我必须了解向量是如何工作的,但我想我大部分都理解这个概念。它们似乎比数组更适合我要做的事情…所以也谢谢你指出这一点。
std::vector<IntOrFloat> convert( const std::vector<std::string> t, const std::string s ){
std::vector<IntOrFloat> results;
std::vector<std::string> hexes = split( s );
for( int i = 0; i < hexes.size(); i++ ){
if( t[i] == "1" ){
results.push_back( IntOrFloat( convFloat( hexes[i] ) ) );
} else {
results.push_back( IntOrFloat( convInt( hexes[i] ) ) );
}
}
return results;
}
std::vector<std::string> fromArray( std::string strs[], int n ){
std::vector<std::string> strings;
for( int i = 0; i < n; i++ ) strings.push_back( std::string( strs[i] ) );
return strings;
}
#define fromArray(a) fromArray( a, (sizeof(a)/sizeof(a[0])) )
#define LENGTH(a) (sizeof(a)/sizeof(a[0]))
int main(){
std::string t[] = {"2","1","1","2"};
std::string s[] = {
"8000,4048f5c3,bf000000,FFFF",
"0001,42f6e979,c44271ba,7FFF",
"1234,00000000,447a0000,5678"
};
std::vector<std::string> types = fromArray( t );
std::vector<std::string> strings = fromArray( s );
for( std::vector<std::string>::iterator it = strings.begin() ; it != strings.end(); ++it ){
std::vector<IntOrFloat> results = convert( types, *it );
std::cout << "converting string " << *it << ", " << results.size() << " values:" << std::endl;
for( std::vector<IntOrFloat>::iterator iof = results.begin() ; iof != results.end(); ++iof ){
std::cout << " " << *iof << std::endl;
}
}
}