将复杂的C++转换转换为 C#
Convert complex C++ casts to C#
我正在将一些C++代码移植到C#。
直到现在,理解它并不难。
在C++,我发现:
#define TWO_POW(n) ((double)(1ULL<<(n)))
static int someFunction(uint32_t someValue, uint32_t otherValue)
{
int32_t someVar;
someVar = ((someValue * TWO_POW(22)) / otherValue) * (-1);
/* ...use someVar in some other code */
}
我看不出这是如何处理的,以及如何将其转换为 C# 代码。
不确定是否:
someVar = (int) (((((double)(long)someValue) * ((double)(1L << 22))) / otherValue) * (-1));
将在 C# 中完成同样的事情。
我认为您的尝试过于复杂 - 以下内容适用于我,使用几个不同的值进行测试:
someVar = (int)((someValue * ((double)(1UL << (22)))) / otherValue) * (-1);
(请注意,"uint32_t"转换为"uint","int32_t"转换为"int" - 此外,C++"ULL"后缀在C#中转换为"UL",而不是"L")。
相关文章:
- 防止主数据类型C++的隐式转换
- 模板参数替换失败,并且未完成隐式转换
- 努力将整数转换为链表。不知道我在这里做错了什么
- HEX值到wchar_t字符(UTF-8)的转换
- lambda参数转换为constexpr技巧,然后获取带链接的数组
- 将 Qvector<uint8_t> 转换为 QString
- 如何在cuSparse中使用cusparseXcoo2csr从coo转换为csc
- 有关插入适配器的错误。[错误]请求从 'back_insert_iterator<vector<>>' 类型转换为非标量类型
- 在c++中使用nlohmann从类到json的转换
- 从"int*"强制转换为"unsigned int"会丢失精度错误
- 将Integer转换为4字节的unsined字符矢量(按大端字节顺序)
- 处理小于cpu数据总线的数据类型.(c++转换为机器代码)
- 如何使用OpenCV将RBG图像转换为HSV,并将H、S和V值保存为C++中的3个独立图像
- 复制列表初始化的隐式转换的等级是多少
- 正在将指针转换为范围
- 如何防止 c++ 在从浮点型转换为双精度型(不适用于 IO)时添加额外的小数?
- 将"打开的CV图像"中的"颜色"转换为整数格式
- 是否可以从int转换为enum类类型
- 了解 GLM- openGL 中的相机转换
- 将无符号char*转换为std::istream*C++