0

所以我一辈子都不知道如何找到这个 NullReferenceError。我为一个名为 ScannerHelper 的程序编写了一个库。它的唯一目的是打开和关闭条形码阅读器。它运行的程序我无法访问源代码,但我经常与程序员交谈,这让我们俩都难过。这是我们设置的跟踪。

痕迹

OpenBarPort: Try Opening Barcode port
    ScannerHelper Information: 0 : (0):Open(COM6)+
    ScannerHelper Information: 0 : (0):IsValidNewlandScanner(COM6)+
    ScannerHelper Information: 0 : (0):HasValidName(COM6)+
    ScannerHelper Information: 0 : (0):HasValidName(True)-
    ScannerHelper Information: 0 : (0):CheckForNewlandScanner(COM6)+
    ScannerHelper Information: 0 : (0):WriteCommand(3F)+
    ScannerHelper Information: 0 : (0):WriteCommand()-
    ScannerHelper Information: 0 : (0):ReadResponse()+
    ScannerHelper Information: 0 : (0):ReadResponse(21)-
    ScannerHelper Information: 0 : (0):CheckForNewlandScanner(True)-
    ScannerHelper Information: 0 : (0):IsValidNewlandScanner(True)-
    ScannerHelper Information: 0 : (0):set_port()+
    ScannerHelper Information: 0 : (0):set_port(34786562)-
    ScannerHelper Information: 0 : (0):ScannerOn(34786562)+
    ScannerHelper Information: 0 : (0):ScannerOn()-
    ScannerHelper Information: 0 : (0):Open(OPOS_SUCCESS)-

Unhandled Exception: System.NullReferenceException: Object reference not set to an instance of an object.
at System.Threading._IOCompletionCallback.PerformIOCompletionCallback(UInt32 errorCode, UInt32 numBytes, NativeOverlapped* pOVERLAP)

所以他调用的方法OpenBarPort有一个 try/catch ,我的 ScannerHelper.Open 有一个 try catch 来处理所有事情。令人讨厌的是,他和我的 try/catch 语句都没有捕捉到任何东西。但是,如果他注释掉我的 Open Method,问题就会消失。

这是我的 Open 方法代码,为了清楚起见,我取出了额外的跟踪代码。

public int Open(string portName)
{
    if (portName == null)
        portName = "";

    if (!IsValidNewlandScanner(portName))
        return OPOS_E_FAILURE;

    try
    {
        scannerPort = new System.IO.Ports.SerialPort(portName);
        scannerPort.DataReceived += scannerPort_DataReceived;
        scannerPort.Open();

        if (trigger is CPScannerTrigger)
        {
            //Sets the SafeFileHandle
            (trigger as CPScannerTrigger).port = scannerPort;
        }
        trigger.ScannerOn();
        trigger.Opened = true;
    }
    catch (System.Exception ex)
    {
        Globals.TraceError(ex);
        return OPOS_E_FAILURE;
    }
    return OPOS_SUCCESS;
}

扫描仪触发器

public override void ScannerOn()
{
    Globals.TraceStart(handle.GetHashCode());
    CP210xRT_WriteLatch(handle, 4, 0);
    Globals.TraceEnd();
}

public override void ScannerOff()
{
    Globals.TraceStart(handle.GetHashCode());
    CP210xRT_WriteLatch(handle, 4, 4);
    Globals.TraceEnd();
}

public System.IO.Ports.SerialPort port
{
    set
    {
        Globals.TraceStart();
        handle = GetHandleFromSerialPort(value);
        Globals.TraceEnd(handle.GetHashCode());
    }
}
private Microsoft.Win32.SafeHandles.SafeFileHandle GetHandleFromSerialPort(System.IO.Ports.SerialPort sp)
{
    var BaseStream = sp.BaseStream;
    var baseStreamType = BaseStream.GetType();
    var flags = System.Reflection.BindingFlags.NonPublic | System.Reflection.BindingFlags.Instance;
    return baseStreamType.GetField("_handle", flags).GetValue(BaseStream) as Microsoft.Win32.SafeHandles.SafeFileHandle;
}
private Microsoft.Win32.SafeHandles.SafeFileHandle handle;

所以我从来没有见过这种类型的空引用错误。如果不是因为我有可能使用 2 个条形码扫描仪,我只会将 SafeFileHandle 标记为静态。我觉得奇怪的是,在 Open 返回后立即触发错误。我的条形码扫描仪打开,所以我知道触发器“有效”,但我不确定是什么导致了这个问题。当我在 NUnit 中运行单元测试时,它不会抛出异常。有人可以提供帮助吗?:) 谢谢。

4

0 回答 0