Which variables should I typecast when doing math operations in C/C++?
来源:互联网 发布:win7美化桌面软件 编辑:程序博客网 时间:2024/06/15 19:36
原帖: http://stackoverflow.com/questions/245740/which-variables-should-i-typecast-when-doing-math-operations-in-c-c
===============================================================================================================================
For example, when I'm dividing two ints and want a float returned, I superstitiously write something like this:
int a = 2, b = 3;float c = (float)a / (float)b;
If I do not cast a
and b
to floats, it'll do integer division and return an int.
Similarly, if I want to multiply a signed 8-bit number with an unsigned 8-bit number, I will cast them to signed 16-bit numbers before multiplying for fear of overflow:
u8 a = 255;s8 b = -127;s16 = (s16)a * (s16)b;
How exactly does the compiler behave in these situations when not casting at all or when only casting one of the variables? Do I really need to explicitly cast all of the variables, or just the one on the left, or the one on the right?
===============================================================================================================================Question 1: Float division
int a = 2, b = 3;float c = static_cast<float>(a) / b; // need to convert 1 operand to a float
Question 2: How the compiler works
Five rules of thumb to remember:
- Arithmetic operations are always performed on values of the same type.
- The result type is the same as the operands (after promotion)
- The smallest type arithmetic operations are performed on is int.
- ANSCI C (and thus C++) use value preserving integer promotion.
- Each operation is done in isolation.
The ANSI C rules are as follows:
Most of these rules also apply to C++ though not all types are officially supported (yet).
- If either operand is a long double the other is converted to a long double.
- If either operand is a double the other is converted to a double.
- If either operand is a float the other is converted to a float.
- If either operand is a unsigned long long the other is converted to unsigned long long.
- If either operand is a long long the other is converted to long long.
- If either operand is a unsigned long the other is converted to unsigned long.
- If either operand is a long the other is converted to long.
- If either operand is a unsigned int the other is converted to unsigned int.
- Otherwise both operands are converted to int.
Overflow
Overflow is always a problem. Note. The type of the result is the same as the input operands so all the operations can overflow, so yes you do need to worry about it (though the language does not provide any explicit way to catch this happening.
As a side note:
Unsigned division can not overflow but signed division can.
std::numeric_limits<int>::max() / -1 // No Overflowstd::numeric_limits<int>::min() / -1 // Will Overflow
==============================================================================================================================In general, if operands are of different types, the compiler will promote all to the largest or most precise type:
If one number is... And the other is... The compiler will promote to...------------------- ------------------- -------------------------------char int intsigned unsigned unsignedchar or int float floatfloat double double
Examples:
char + int ==> intsigned int + unsigned char ==> unsigned intfloat + int ==> float
Beware, though, that promotion occurs only as required for each intermediate calculation, so:
4.0 + 5/3 = 4.0 + 1 = 5.0
This is because the integer division is performed first, then the result is promoted to float for the addition.
==============================================================================================================================- Which variables should I typecast when doing math operations in C/C++?
- when should BOOL and bool be used in c
- Which should I use in my DTD, attributes or elemen
- Static variables in c programming
- Why / When / How should I use exception in Python ?
- When should you use a class vs a struct in C++?
- Which Extension Should I Use?
- What should main() return in C/C++?
- When should I use shutdown()?
- When Should I Use HBase
- Which I/O Strategy Should I Use?
- Why should you choose fstream classes for file I/O in C++?
- Question 11: Which of the following statements describe the result when standard new cannot allocate the requested storage in C+
- Which of the following expression(s) will NOT cause an error when used to replace the ***** in the C
- Which style of WSDL should I use?
- Which style of WSDL should I use?
- Which style of WSDL should I use?
- Which style of WSDL should I use?
- wzplayer for android V1.0快出炉了
- 代码能力
- poj_1787
- 内联函数与宏的区别
- c/c++ 内存管理与分配总结
- Which variables should I typecast when doing math operations in C/C++?
- hadoop入门阅读
- [TYVJ-1088] DP
- Oracle中TO_DATE格式用法
- Range Minimum Query and Lowest Common Ancestor
- 与众不同的技术社区
- 毕业后五年之内将决定你的一生 人生与励志
- RGB序列排序
- IOS的消息循环