If you question around about a mainstream object oriented language, most people will point to Java, or C#. Sure that C++ has classes, and objects, inheritance, polymorphism... but it's not really object oriented, there are still non-member functions, and that is just so no-OO. Or is it?
Thursday, July 28, 2011
Operator overloading, OO the C++ way
Labels:
C++,
free function,
interface,
member function
Saturday, July 23, 2011
Implementating vs. understanding
Solving a problem and actually understanding what the problem is do not always go hand by hand. Many times not just the problem eludes understanding, but even the solution we just wrote.
Thursday, July 21, 2011
Improving conversions of std::pair<T,U>
s
As we already saw, even if the implementations are more permisive, the standard mandates that conversions from
But what about explicit conversions? Do we need to fail there? It would seem appropriate if, given two types that are explicitly convertible, we allowed explicit conversions of the
std::pair<>
types should use only implicit conversions. That solves only half of the problem: when two types are implicitly convertible, then std::pair<>
containing those types are also implicitly convertible.But what about explicit conversions? Do we need to fail there? It would seem appropriate if, given two types that are explicitly convertible, we allowed explicit conversions of the
std::pair
.Wednesday, July 20, 2011
Conversions of std::pair<T,U>
s
I decided to start writing a few months ago, but I never actually committed to it. Then I decided a few days ago that I was actually going to do it, and I have spent the last few days trying to decide what would be a good first post. I am still undecided. But today I read an interesting question in StackOverflow, and decided to write about it.
The problem Rafał has is with implicit conversions. In his application he has two types that are convertible, but only explicitly convertible. He is surprised that an
The problem Rafał has is with implicit conversions. In his application he has two types that are convertible, but only explicitly convertible. He is surprised that an
std::pair<>
that contains one of those types is implicitly convertible to a std::pair<>
of that contains the second type.
Subscribe to:
Posts (Atom)