1、获取指定类型的最大值和最小值
在准备求一堆double数据中的最大值最小值的时候,常规做法是预估这堆数据的最大最小值,然后进行比较求,在重构别人代码的时候发现,可以准确知道double类型最大值或者最小值,获取方法如下
double min_h = (std::numeric_limits<double>::max)();//把double类型的最大值赋给min_h变量
double max_h = std::numeric_limits<double>::lowest();//把double类型的最小值赋给max_h变量
执行后
以此类推,这种方法可以准确获取int类型、float类型等
2、static_cast把void*类型强转到指定类型
该运算符把expression转换为type-id类型,但没有运行时类型检查来保证转换的安全性。
注意:static_cast不能转换掉expression的const、volatile、或者__unaligned属性。
用法:
static_cast <type-id>( expression )
C++中的static_cast执行非多态的转换,用于代替C中通常的转换操作。因此,被做为显式类型转换使用。比如:
double a = 3.14159;
double a2 = 3.64159;
int b = static_cast<int>(a);
int b2 = static_cast<int>(a2);
此时结果,如下(调试状态,代码执行到下面,调试断点截图未显示):
3、reinterpret_cast把void*类型强转到指定类型
C++中的reinterpret_cast主要是将数据从一种类型的转换为另一种类型。所谓“通常为操作数的位模式提供较低层的重新解释”也就是说将数据以二进制存在形式的重新解释。比如:
unsigned char* p = new unsigned char[50]{ "Hello world!\n" };
int* c = reinterpret_cast<int*>(p);
此时结果,如下(调试状态,代码执行到下面,调试断点截图未显示)