在c++中正确的强制类型转换
Casting the proper way in C++
如果这不是一个足够好的问题,我很抱歉(因为我自己的解决方案只是工作,所以我实际上没有问题),但这里是。
我的意思是,我是用C语言长大的,后来才学会c++,所以可能我有偏见,但仍然。
在这种特殊情况下,有一个库返回const char*
,而另一个库需要void*
作为输入。因此,如果我想用第一个库的结果调用第二个库,我需要写
second(const_cast<void*>(static_cast<const void*>(first())));
对吧?这是唯一正确的方法,对吗?
char*
可以隐式地转换为void*
,因此您的代码可以简化为:
second(const_cast<char*>(first()));
只有当second
的定义操作时,其形参的类型为const void*
时,
相关文章:
- 有关插入适配器的错误。[错误]请求从 'back_insert_iterator<vector<>>' 类型转换为非标量类型
- 处理小于cpu数据总线的数据类型.(c++转换为机器代码)
- C++中的双指针类型转换
- 逐位操作的隐式类型转换
- 模板中的类型转换
- 在 C++(和 C)中进行类型转换时明显不一致
- 字符类型转换不兼容
- 将复杂的非基元C++数据类型转换为 Erlang/Elixir 格式,以使用 NIF 导出方法
- C++:用户定义的显式类型转换函数错误
- 将类指针类型转换为键时出错
- 通过引用传递参数时C++类型转换
- 在 C++ 中将一个模板类型的对象类型转换为另一个模板类型
- C++显式类型转换(C 样式强制转换)的强制表示法和static_cast的多种解释
- C++无效的函数类型转换
- 在将派生类指针类型转换为派生类指针后,从基类指针调用派生类函数
- 如何将Windows产品类型转换为名称?
- 通过构造函数方法输出的类到类类型转换是 5500 为什么不是 5555
- 事件系统:使用类型转换或联合进行继承
- 如何在参数中定义隐式类型转换的构造函数?
- 类模板实例化中的类型转换