I want to make sure that my understanding of the return type of C++ division,
int / int => return is int?
float / float => return is which type? float?
d
All of those are correct. Here's what the C++03 standard says (§5/9):
Many binary operators that expect operands of arithmetic or enumeration type cause conversions and yield result types in a similar way. The purpose is to yield a common type, which is also the type of the result. This pattern is called the usual arithmetic conversions, which are defined as follows:
- If either operand is of type
long double, the other shall be converted tolong double.- Otherwise, if either operand is
double, the other shall be converted todouble.- Otherwise, if either operand is
float, the other shall be converted tofloat.- Otherwise, the integral promotions (4.5) shall be performed on both operands.
- Then, if either operand is
unsigned longthe other shall be converted tounsigned long.- Otherwise, if one operand is a
long intand the otherunsigned int, then if along intcan represent all the values of anunsigned int, theunsigned intshall be converted to along int; otherwise both operands shall be converted tounsigned long int.- Otherwise, if either operand is
long, the other shall be converted tolong.- Otherwise, if either operand is
unsigned, the other shall be converted tounsigned.[Note: otherwise, the only remaining case is that both operands are
int]