Dizenin büyük alır gibi 50 kb sırasını veya daha büyük (örneğin, bir veritabanından bir HTML tablosu), büyük dizeleri bitiştirmek zaman tamamlamak için gereken sürenin uzunluğunu oldukça uzun hale gelebilir. Bu makalede, bir seçenek büyük dizelerinin 20 kez veya daha fazla performansı artırabilir, normal birleştirme gösterilmektedir.
Yinelenen concatenations türü gerçekleştirirken:
For I = 1 To N
Dest = Dest & Source
Next N
orantılı olarak çok N kare süresi artar. Bu nedenle, 1000 yinelemeden 100 yinelemeden yaklaşık 100 kez daha uzun sürer. Bunun nedeni, kaynak karakterler hedef dizenin sonuna'ı eklemez yalnızca Visual Basic; da aşağıdaki işlemleri gerçekleştirir:
- Sonuç alacak kadar büyük olan geçici bellek ayırır.
- Hedef geçici alanın başlangıcına kopyalar.
- Kopya kaynağı geçici alanın sonuna.
- Hedef eski bir kopyasını de-allocates.
- Bellek hedef sonucu alacak kadar büyük ayırır.
- Geçici veri için hedef kopyalar.
2 Ve 6 numaralı adımları çok pahalıdır ve temel olarak ayırmak ve bellek de-allocate için iki kez ek yük ile kopyalanan tüm art arda eklenmiş sonuç olur.
Bu makalede, Mid $ deyimini kullanarak ve tüm adım yukarıdaki 3 birleştirme aşamasına çoğunu ortadan kaldırmak için daha büyük boyutta bellek pre-allocating yöntemi ayrıntıları.
UYARI: TÜM, BU MAKALEDE SAĞLANAN KOD TARAFINDAN KENDİ SORUMLULUà ° UNUZDADýR KULLANILIR. Microsoft, hiçbir garanti, ya da veya zımni, dahil ancak bunlarla sınırlı olmamak satılabilirlik ve/veya belirli bir amaca uygunluk zımni hiçbir garanti olmadan "olduğu gibi", bu kodu sağlar.
Adım adım örnek
- Bir modüle aşağıdaki kodu yazın:
Option Explicit
' For 16-bit products, uncomment the next three lines by removing the
' single quotes and add a single quote to comment out the following
' three lines.
' Const ConcatStr = "ABC"
' Const ccIncrement = 15000
' Declare Function GetTickCount Lib "USER" () As Long
Const ConcatStr = "ABCDEFGHIJKLMNOPQRSTUVWXYZ"
Const ccIncrement = 50000
Private Declare Function GetTickCount Lib "KERNEL32" () As Long
Dim ccOffset As Long
Sub StdConcat(ByVal LoopCount As Long)
Dim BigStr As String, I As Long, StartTick As Long
StartTick = GetTickCount()
For I = 1 To LoopCount
BigStr = BigStr & ConcatStr
Next I
Debug.Print LoopCount; "concatenations took";
Debug.Print GetTickCount() - StartTick; "ticks"
End Sub
Sub Test_Concat()
Debug.Print "Using standard concatenation"
StdConcat 1000
StdConcat 2000
StdConcat 3000
StdConcat 4000
StdConcat 5000
Debug.Print
Debug.Print "Using pre-allocated storage and pseudo-concatenation"
MidConcat 1000
MidConcat 2000
MidConcat 3000
MidConcat 4000
MidConcat 5000
End Sub
Sub Concat(Dest As String, Source As String)
Dim L As Long
L = Len(Source)
If (ccOffset + L) >= Len(Dest) Then
If L > ccIncrement Then
Dest = Dest & Space$(L)
Else
Dest = Dest & Space$(ccIncrement)
End If
End If
Mid$(Dest, ccOffset + 1, L) = Source
ccOffset = ccOffset + L
End Sub
Sub MidConcat(ByVal LoopCount As Long)
Dim BigStr As String, I As Long, StartTick As Long
StartTick = GetTickCount()
ccOffset = 0
For I = 1 To LoopCount
Concat BigStr, ConcatStr
Next I
BigStr = Left$(BigStr, ccOffset)
Debug.Print LoopCount; "pseudo-concatenations took";
Debug.Print GetTickCount() - StartTick; "ticks"
End Sub
- Debug/hemen penceresinde Test_Concat yazın ve ENTER tuşuna basın.
Sonuçları benzer şekilde görünür:
Using standard concatenation
1000 concatenations took 2348 ticks
2000 concatenations took 8954 ticks
3000 concatenations took 20271 ticks
4000 concatenations took 35103 ticks
5000 concatenations took 54453 ticks
Using pre-allocated storage and pseudo-concatenation
1000 pseudo-concatenations took 82 ticks
2000 pseudo-concatenations took 124 ticks
3000 pseudo-concatenations took 165 ticks
4000 pseudo-concatenations took 247 ticks
5000 pseudo-concatenations took 289 ticks
Ek bilgi
- Kodu birkaç çalıştırmak için bir dakika sürebilir.
- Windows yeniden başlatıldıktan sonra GetTickCount milisaniye sayısını döndürür. Bu nedenle, çıktı milisaniyedir.
- Performans geliştirme aralığından için yaklaşık 30 saatleri 1000 yinelemenin durum için yaklaşık 200 zamanları 5000 yinelemenin durumda. Bu kez bağlı olarak değişebilir:
- Kullanılan ürün.
- Sisteminizin yapılandırması
- CcIncrement boyutuna (daha büyük boyutta MidConcat ayrıcalıklı kılar).
- Kullanılan yineleme sayısını (MidConcat daha fazla yineleme ayrıcalıklı kılar).
- Sonuç dizesini (daha büyük boyutta MidConcat ayrıcalıklı kılar) olarak boyutu.
Ek bilgi için, Microsoft Bilgi Bankası'ndaki makaleyi görüntülemek üzere aşağıdaki makale numarasını tıklatın:
306821
(http://support.microsoft.com/kb/306821/EN-US/
)
Nasıl yapılır: Visual Basic. NET'te dize bitiştirme performansı artırma