3

C++ 中的“if(arg2 & 1)”行(arg2 是 DWORD)等于 C#(arg2 是 Uint32)中的“if(arg2 & 1==0)”,对吗?

我正在尝试将函数从 C++ 转换为 C#,但出现错误:

Operator '&' cannot be applied to operands of type 'uint' and 'bool'

如果您能在整个函数中进一步了解任何其他错误,我也将不胜感激。

C++

DWORD Func_X_4(DWORD arg1, DWORD arg2, DWORD arg3)
{
LARGE_INTEGER result = {1, 0};
LARGE_INTEGER temp1 = {0};
LARGE_INTEGER temp2 = {0};
LARGE_INTEGER temp3 = {0};
LARGE_INTEGER temp4 = {0};
for(int x = 0; x < 32; ++x)
{
    if(arg2 & 1)
    {
        temp1.LowPart = arg3;
        temp1.HighPart = 0;
        temp2.QuadPart = temp1.QuadPart * result.QuadPart;
        temp3.LowPart = arg1;
        temp3.HighPart = 0;
        temp4.QuadPart = temp2.QuadPart % temp3.QuadPart;
        result.QuadPart = temp4.QuadPart;
    }
    arg2 >>= 1;
    temp1.LowPart = arg3;
    temp1.HighPart = 0;
    temp1.QuadPart *= temp1.QuadPart;
    temp2.LowPart = arg1;
    temp2.HighPart = 0;
    temp3.QuadPart = temp1.QuadPart % temp2.QuadPart;
    arg3 = temp3.LowPart;
    if(!arg2)
        break;
}
return result.LowPart;
}

转换为 C#

LARGE_INTEGER 结构:

[StructLayout(LayoutKind.Explicit, Size = 8)]
public struct LARGE_INTEGER
{
    [FieldOffset(0)]
    public Int64 QuadPart;
    [FieldOffset(0)]
    public UInt32 LowPart;
    [FieldOffset(4)]
    public Int32 HighPart;
}

功能:

public static UInt32 X4(UInt32 arg1, UInt32 arg2, UInt32 arg3)
    {
        LARGE_INTEGER result = new LARGE_INTEGER();
        result.LowPart = 1;
        result.HighPart = 0;
        LARGE_INTEGER temp1 = new LARGE_INTEGER();
        LARGE_INTEGER temp2 = new LARGE_INTEGER();
        LARGE_INTEGER temp3 = new LARGE_INTEGER();
        LARGE_INTEGER temp4 = new LARGE_INTEGER();
        for (int x = 0; x < 32; ++x)
        {
            if (arg1 & 1 ==0)
            {
                temp1.LowPart = arg3;
                temp1.HighPart = 0;
                temp2.QuadPart = temp1.QuadPart * result.QuadPart;
                temp3.LowPart = arg1;
                temp3.HighPart = 0;
                temp4.QuadPart = temp2.QuadPart % temp3.QuadPart;
                result.QuadPart = temp4.QuadPart;
            }
            arg2 >>= 1;
            temp1.LowPart = arg3;
            temp1.HighPart = 0;
            temp1.QuadPart *= temp1.QuadPart;
            temp2.LowPart = arg1;
            temp2.HighPart = 0;
            temp3.QuadPart = temp1.QuadPart % temp2.QuadPart;
            arg3 = temp3.LowPart;
            if (arg2==0)
                break;
        }
        return result.LowPart;
    }

这是我还不确定的:

  1. C++ 中的 DWORD 是 C# 中的 UInt32 还是 Int32?
  2. if(integer & integer) 表示 if(integer and integer ==0)?//这是我上面描述的错误所在的地方。
  3. if(!integer) 表示 if(integer != 0)?
  4. 为什么运算符 & 不能在 C# 中逻辑使用,这意味着它需要一个布尔值?
  5. "LARGE_INTEGER 结果 = {1, 0}" 表示 result.lowpart 为 1 且 result.highpart 为 0 或 result.Quadpart = 1?

提前致谢!

4

3 回答 3

11

你写的地方:

如果 (arg1 & arg2==0)

编译器理解:

if (arg1 & (arg2==0))

你应该写:

if ((arg1 & arg2) == 0)

这是应该将 C++ 语句转换为 C# 的方式:

if (arg2 & 1) // C++ (arg2 is DWORD)
if ((arg2 & 1) != 0) // C# (arg2 is Uint32)

或者,以更通用的方式:

if (Flags & FlagToCheck) // C++
if ((Flags & FlagToCheck) != 0) // C#

在 C/C++ 中,0 为假,其他一切为真。

  1. 您应该检查 DWORD 的定义,它应该是 (unsigned int),在 C# 中是 UInt32
  2. if (integer & integer),在 C/C++ 中的意思是“如果按位和两个整数之间的结果不为 0”(0 为假,其他一切为真)。
  3. if (!integer) 表示 if (integer == 0) (同样,0 为假,其他一切为真)
  4. 在 C# 中,就像在 Java 中一样,我认为布尔值和数字是两个不同的东西,你只能在“if”语句中使用布尔值,如果你使用 int 则没有隐式转换:它不会编译。
  5. 我会把这个留给别人,我需要测试以确保...
于 2009-03-26T11:54:27.963 回答
4
  1. DWORDuint32_tC++ 中,因此UInt32在 C# 中。
  2. if(a & b)转换为if((a & b) != 0). !=被评估,&因此&表达式需要括号括起来。
  3. if(x)转换为if(x != 0)
  4. &在 C# 中是“按位与”,就像在 C++ 中一样。
  5. 取决于您的 C++ 结构。
于 2009-03-26T11:57:44.773 回答
1

5 - 这意味着两者。因为 LowPart 和 HighPart 只是进入 QuadPart 内存的“窗口”,所以当 result.LowPart == 1 且 Result.HighPart == 0 时,result.QuadPart 将等于 1。

于 2009-03-26T12:12:23.037 回答