Re: What's your preferred way of returning a list of items?
On May 12, 11:18 am, DeMarcus <use_my_alias_h...@hotmail.com> wrote:
Hi,
Here are a couple of ways to return some list of items.
struct A
{
};
std::vector<A> aList; // Some list of items.
// Returning a copy.
std::vector<A> getList() { return aList; }
void getList( std::vector<A>& v )
{
std::copy( aList.begin(), aList.end(), v.begin() );
}
void getList( std::vector<A>* v )
{
std::copy( aList.begin(), aList.end(), v->begin() );
}
// Returning a reference to aList.
const std::vector<A>& getList() { return aList; }
const std::vector<A>::const_iterator& getList()
{
return aList.begin();
}
Do you know more ways to return a list? What's your preferred way to
return a list of items?
Also, here comes another trickier one. Let's say I have a map instead
and want to return the keys.
std::map<std::string, A> aMap;
// Returning a copy of the keys.
std::vector<std::string> getList()
{
std::vector<std::string> aKeys;
auto keysEnd = aMap.end();
for( auto i = aMap.begin(); i != keysEnd; ++i )
aKeys.push_back( (*i).first );
return aKeys;
}
void getList( std::vector<std::string>& v )
{
auto keysEnd = aMap.end();
for( auto i = aMap.begin(); i != keysEnd; ++i )
v.push_back( (*i).first );
}
void getList( std::vector<std::string>* v )
{
auto keysEnd = aMap.end();
for( auto i = aMap.begin(); i != keysEnd; ++i )
v->push_back( (*i).first );
}
// But is it even possible to return a reference to
// the keys in a map?
const std::vector<std::string>& getList() { /* What here? */ }
const std::vector<std::string>::const_iterator& getList()
{
/* What here? */
}
How do you usually deal with these kind of list returns?
Usually...
I avoid writing functions that are getters, copiers or even worse ...
setters, because these indicate lousy design. I usually try my best to
have interface that allows operations that make sense to do with the
objects of given type and not interface that allows mechanical
setting, getting and copying of the properties of objects.
My functions that are still getters are nouns (remove "get" prefix,
once situation enforces to be lousy, go maximum) and are either
returning copies or const references. My functions that fill their
parameters with a copy of internal data start with "copy" and i call
them copiers. Setters are also nouns (no "set" prefix; have to be java
so go maximum) but return void and take const reference as parameter.
I call std::vector as "a vector" and std::list as "a list". There are
no further deep reasons for such conventions; one just has to stick to
something over years.