我尝试将不同的变量值分配给循环中的double数组,但整个数组只有1个值
double *float_array;
float_array = new double [dynamic_variable]; // debugger does tell me its size
stringstream ss1(line);
string s1;
string s2 = "2.1";
double test= atof(s2.c_str());
while (getline(ss1,s1,','))
{
float_array[count] = atof(s1.c_str());
count++;
}
count = 0;
root->data = float_array;
root->next = new node;
显示更多代码
class node
{
public:
double * data;
node *next;
node(void);
~node(void);
};
int _tmain(int argc, _TCHAR* argv[])
{
double arr[4]= {0.689997};
double * float_array;
string file_name;
string line,token;
string path= "D:\\DM\\Assignment No. 1\\";
cin>>file_name;
file_name= path + file_name;
ifstream aa;
aa.open(file_name,ios::in|ios::out);
node *root; int float_arr_size=0;int count=0;
//aa.open(file_name,ios::in|ios::out);
if(aa.is_open())
{
while(!aa.eof())
{
aa>>line;
cout<<line<<endl;
cout<<endl;
stringstream ss(line);
string s;
while (getline(ss, s, ','))
{
float_arr_size++;
}
float_array= new double[float_arr_size];
s="";
stringstream ss1(line);
string s1;
string s2= "2.1";
double test= atof(s2.c_str());
while(getline(ss1,s1,','))
{
float_array[count] = atof(s1.c_str());
count++;
}
count = 0;
root->data =float_array;
root->next= new node;
}
}
aa.close();
return 0;
}
我的测试变量得到了完美的转换。我在s1
中得到“2.1”,但在调试器中,我在float_array中只得到一个值为5.0999945的值。没有其他索引有任何进一步的值。在正确转换测试变量值后,我在动态数组中看到了问题。
请问有解决方案吗?
答案 0 :(得分:1)
代码already works。 C和C ++是低级语言,其方式往往会隐藏调试器中的信息,但信息仍会显示std::cout <<
。
将此与可能存在错误的可能性相结合,这些错误可能会使调试器完全无用,并且在没有特殊工具的情况下验证程序功能是个好主意。这个问题有点偏离主题,但它可能有助于解释社区的总体方向。
答案 1 :(得分:1)
关于调试器没有显示整个数组的评论,在Visual Studio调试器中为C / C ++添加一个类似的手表:
float_array,30
这将显示数组的30个元素。请记住,这不是动态的,它会愉快地显示30个长度数组的元素!= 30所以你必须以其他方式知道数组的长度并根据需要修改手表。如果您想要更“友好”的调试器行为,可以使用std :: vector。事实上,你可能应该使用std :: vector,除非你真的享受手动内存管理。
编辑:好的我在注释中注意到“赋值”这个词,所以也许你被迫使用手动内存管理:)
答案 2 :(得分:0)
嗯,我在你的代码中看到的唯一问题是你从未存储放在float_array中的项目数量,所以我看不出你以后如何确定它。
由于指针在C ++上的工作方式,大多数调试器在被要求使用double *时,只会显示数组的第一项。实际上,调试器无法知道该指针是指向单个项目还是指向数组(如果它是一个动态创建的数组,它包含多少项目)......这就是我所经历的使用Visual Studio和Eclipse CDT调试器。但是你的数据应该在那里,尝试在你的调试器(或打印到控制台)上输入float_array [1]或float_array [2]中的值。