I am new to C++. For a school project I need to make a function which will be able to return a string array.
Currently I have this in my header:
Config.h
string[] getVehicles(void);
Config.cpp
string[] Config::getVehicles(){
string test[5];
test[0] = "test0";
test[1] = "test1";
test[2] = "test2";
test[3] = "test3";
test[4] = "test4";
return test;}
Obviously this does not work but that's the idea of what I am trying to do. In Java this would be the way to do it. I've tried googling my problem but I didn't come across any answers that were clear to be honest.
In C++ you don't use an array, but a
std::vector
instance. Arrays in C++ must have a compile-time fixed length whilestd::vector
instances can change their length at runtime.std::vector
can also grow dynamically, so in a C++ program you will find more often something likeAllocating dynamically an array of
std::string
is technically possible but a terrible idea in C++ (for example C++ doesn't provide the garbage collector that Java has).If you want to program in C++ then grab a good C++ book and read it cover to cover first... writing Java code in C++ is a recipe for a disaster because the languages, despite the superficial braces similarity, are very very different in many fundamental ways.
Use a
std::vector<std::string>
. It's much easier to deal with thanC
-style arrays.Check out the other containers in the standard library, they are almost always a better choice than plain arrays in C++.
If your
getVehicles
method doesn't change theConfig
object's state, consider making itconst
:Maybe it is better to use a vector in this case, but this is not a correct answer for the question. The reason why it doesn't work is that the variable test just exists in the scope of your function. So you have to manage the memory on your own. Here is an example:
In this case you return a pointer of the position in the heap. All the memory in the heap has to free manually. So it is now your work to delete the memory, if you don't need it anymore:
Try this
For example, in my computer, the result is
Getting addresses and contents of addresses could help you to understand that an array in c++ is really rudimentary : it offers no methods and you could access an index without allocating memory (the value 6 in the loop). Your first example show a direct allocation of a local array (test), so you can't return it (the local array dies), in this example, the local variable dies also but there is always a variable that access at this part of allocated memory, the function, and then the variable that receive the result of the function, so the variable test is dead after the calling of the function but the memory is still allocated. Regards.