0

我在单例远程对象 MBRO 中使用以下代码。此函数仅在服务器端调用。

''' <summary>
''' Return a cached DataCentricObject
''' </summary>
''' <created_by>CodingBarfield</created_by>
''' <date>04-08-2011</date>
Function DataCentricObjectName(ByVal intID As Integer) As String
    Try
        SyncLock dictDataCentricObject
            If Not dictDataCentricObject.ContainsKey(intID) Then
                Dim st As struct = dcLoader.LoadRecord(intID)
                dictDataCentricObject(intID) = st.Descript
            End If

            Return dictDataCentricObject(intID)
        End SyncLock

    Catch ex As Exception
        Throw New Exception("Error in GetTargName", ex)
    End Try
End Function


Private dictDataCentricObject As New Dictionary(Of Integer, String)
Dim dcLoader As New DataCentricObject

LoadRecord 函数只是从数据库表中读取一行并将字段复制到一个小数据结构中。

问题

  • 此代码多线程安全吗(在远程环境中)
  • 不同的代码是否有任何性能优势
4

1 回答 1

1

这取决于做什么dcLoader.LoadRecord。我猜测这只是读取一些数据而不更新任何状态,我还假设其他访问者dictDataCentricObject锁定了该对象。如果这是真的,那么我认为这段代码是线程安全的。

如果dcLoader.LoadRecord价格便宜,您可以在锁定之前完成以提高并发性。但是,我怀疑它会导致对数据库的调用,因此对于整体性能而言,留在原处可能会更好。这确实意味着对该函数的调用将在访问更昂贵的资源时序列化。当且仅当这会导致您出现性能问题时,您可以在dcLoader.LoadRecord.

于 2011-08-05T08:34:33.767 回答