|
-
January 4th, 2002, 06:32 AM
#1
char* array confusion
Hi,
I am trying to overcome this simple yet confusing problem. I have an array of structures with one char* member. I have used itoa() to convert an integer to char* and stored this in the structure. The problem I have is that after the array of structures has been initialized, all the elements in the array seem to contain the last set value!! This can be seen by running the following program
#include <iostream.h>
#include <stdlib.h>
void main(int argc, char* argv[])
{
struct test
{
char* name;
};
test * structArray = new test[4];
char *temp = new char[4];
for ( int i = 0; i< 4; i++)
{
itoa(i,temp,10);
structArray[i].name = temp;
cout<< structArray[i].name ;
}
cout<< structArray[0].name ;
cout<< structArray[1].name ;
cout<< structArray[2].name ;
cout<< structArray[3].name ;
}
-
January 4th, 2002, 07:09 AM
#2
Re: char* array confusion
This is because of your line:
structArray[ i ].name = temp;
You are merely setting structArray[ i ].name to hold the address of the string. Since you only have one address (temp is only allocated once) all four enties in structArray will hold the same pointer and therefore point at the same string - being the last that you set. To fix it do the following:
for (int i=0; i<4; i++)
{
structArray[ i ].name = new char[4];
itoa(i, structArray[ i ].name, 10);
cout << structArray[ i ].name << endl;
}
You should also bear in mind that an integer could be up to ten characters long so you should allocate 11 bytes for the name (obviously unless you know the value will never be this big).
An alternative would be to adjust the definition of your struct to be:
struct test
{
char name[4];
}
This way you don't need to worry about pointers.
An even better way would be to use std::string.
I hope this helps and doesn't just confuse you even further,
Oliver
-
January 4th, 2002, 03:10 PM
#3
Re: char* array confusion
Hi,
The following code is something better:
#include <iostream.h>
#include <stdlib.h>
#include <string.h>
void main(int argc, char* argv[])
{
struct test
{
char* name;
};
test * structArray = new test[4];
char *temp = new char[4];
for ( int i = 0; i< 4; i++)
{
itoa(i,temp,10);
structArray[i].name = new char[strlen(temp)+1];
strcpy(structArray[i].name,temp);
cout<< structArray[i].name ;
}
cout<< structArray[0].name ;
cout<< structArray[1].name ;
cout<< structArray[2].name ;
cout<< structArray[3].name ;
}
-
January 4th, 2002, 03:19 PM
#4
Re: char* array confusion
Hi,
I am sory i must [blank i blank]write
The following code is something better:
#include <iostream.h>
#include <stdlib.h>
#include <string.h>
void main(int argc, char* argv[])
{
struct test
{
char* name;
};
test * structArray = new test[4];
char *temp = new char[4];
for ( int i = 0; i< 4; i++)
{
itoa(i,temp,10);
structArray[ i ].name = new char[strlen(temp)+1];
strcpy(structArray[ i ].name,temp);
cout<< structArray[ i ].name ;
}
cout<< structArray[0].name ;
cout<< structArray[1].name ;
cout<< structArray[2].name ;
cout<< structArray[3].name ;
}
-
January 7th, 2002, 06:49 AM
#5
Re: char* array confusion
closer but you are only allocating 4 bytes for temp then using as many as 10 bytes in itoa. Of course in your example it won't be a problem as i runs from 0 to 3.
As the maximum length of an integer is 10 digits, you need a buffer of 11 to cover all options.
You are also creating a lot of memory on the heap that (1) you could create locally and (2) you are not deleting later.
Preferably also you should learn to use the Standard Libraries.
Do not use <iostream.h> but <iostream>.
Also rather than itoa (which is not standard) you can use either printf (which at least is) or even more preferably use strstream. With strstream you don't need to worry about allocation.
The best things come to those who rate
Posting Permissions
- You may not post new threads
- You may not post replies
- You may not post attachments
- You may not edit your posts
-
Forum Rules
|
Click Here to Expand Forum to Full Width
|