Alessandra Ambrosio
Alessandra Ambrosio

Reputation: 83

Can strcmp() work with strings in c++?

I have this line of code

if(strcmp(ob[i].getBrand(), ob[j].getBrand()) > 0)

and I get this error

error C2664: 'strcmp' : cannot convert parameter 1 from 'std::string' to 'const char *'

Does that mean that strcmp doesnt work with strings, but instead it has to convert it to char?

Upvotes: 4

Views: 9561

Answers (3)

Mark Garcia
Mark Garcia

Reputation: 17708

Don't use strcmp. Use std::string::compare which has the same behavior as strcmp.

if(ob[i].getBrand().compare(ob[j].getBrand()) > 0)

Or much better

if(ob[i].getBrand() > ob[j].getBrand())

Generally you should use std::string::compare when you have to test various cases where the strings will be different, e.g.

auto cmp = ob[i].getBrand().compare(ob[j].getBrand());

if(cmp == 0) ...
else if(cmp > 0) ...
else if(cmp < 0) ...

In this way you only have to do the comparison operation on the strings once.

However, in your case where it's somehow apparent that you only have to use the comparison result in a single case (I'm really assuming, as I don't know the context of the code given), then operator > will suffice, and is much easier on the eye (the brain!).

Upvotes: 13

nevets
nevets

Reputation: 4828

Simply use .c_str() to convert a string to char array, then you are able to use strcmp().

But in your case, use > is better :)

Upvotes: 2

If getBrand() gives a std::string just use > compare.

Upvotes: 6

Related Questions