บทที่ 7 การเพิ่มประสิทธิภาพการเขียนชุดคำสั่งใน VB.NET

       1.  คลาส Stopwatch
          ในคลาส Stopwatch จะเป็นแหล่งรวมของเมธอดที่ใช้ในการจับเวลาการประมวลผลของซีพียูซึ่งจะบอกเป็นหน่วยมินลิวินาที โดยจะสามารถเข้าถึงหรือเรียกใช้เมธอด Start()  และ Stop() ซึ่งจะแจ้งผลค่าเวลาทางคุณสมบัติ ElapsedMilliseconds
ในคลาสนี้จะอยู่ในเนมสเปซ System.Diagnostics ดังนั้นการใช้งานจะต้องใช้คำสั่ง Import เข้ามาก่อน ซึ่งจะประกาศไว้ส่วนบนของคลาส
|1Imports System.Diagnostics
|2|  Public Class Form1
|3
|4|  End Class
          ในตัวอย่างต่อไปนี้จะเป็นการจับเวลาของคำสั่งการทำซ้ำ เช่น การทำซ้ำ 1 ล้านรอบเวลารวมคือกี่มินลิวินาทีนั้นคือความสามารถของซีพียูในการประมวลผล

          (1)  ให้อออกแบบหน้าจอ ส่วนชื่อของตัวควบคุมนั้นให้ใช้ค่าปริยายของตัวควบคุม ดังภาพ


(2)  ใช้คำสั่งทำซ้ำแบบ For ในการจับเวลาตามจำนวนรอบ จำนวนหนึ่งล้านรอบ โดยไม่มีคำสั่งอะไรในการประมวลผลในการวนรอบ สังเกตจำนวนเวลาที่วนรอบ


|1|  Imports System.Diagnostics
|2|  Public Class Form1
|3|      Private Sub Button1_Click(....) Handles Button1.Click
|4|          Dim objStopwatch As New Stopwatch
|5|          Dim i As Double
|6|          Dim s As String
|7|          objStopwatch.Start()
|8|          For i = 2 To 1000000
|9
|10|         Next
|11|         objStopwatch.Stop()
|12|         MsgBox(objStopwatch.ElapsedMilliseconds)
|13|     End Sub
|14|   End Class
บรรทัดที่ 1 คือการนำเข้าเนมสเปรช System.Diagnostics เพื่อให้เข้าถึงคลาส Stopwatch ได้
บรรทัดที่ 4 คือการสร้างตัวแปรออบเจ็กต์จากคลาส
Stopwatch
บรรทัดที่ 7 คือเมธอดสำหรับสั่งให้เริ่มจับเวลา ณ ซีพียูเริ่มทำงาน
บรรทัดที่ 8 ถึง 10 คือการทำซ้ำแบบ
For จำนวนหนึ่งล้านรอบโดยไม่มีชุดคำสั่งใดๆในคำสั่งนี้
บรรทัดที่ 11 คือ เมธอดสำหรับหยุดการจับเวลาการทำงานของซีพียู
บรรทัดที่ 12 คือ แสดงค่าเวลามีหน่วยเป็นมินลิวินาที ด้วยคุณสมบัติ
ElapsedMilliseconds ทางกล่องข้อความ
(3)  เมื่อรันและแสดงผลจะได้ค่าเวลาซึ่งแต่ละเครื่องที่รันโปรแกรมอาจจะได้ผลที่ต่างกันบ้างเล็กน้อยตามแต่ความเร็วของซีพียู หน่วยเป็นมินลิวินาที ดังภาพ


(3)  จากนั้นให้เพิ่มการประมวลผลโดยในทุกรอบให้เก็บคำว่า รักษ์เลยในบรรทัดที่ 9 เข้าไปทุกรอบ โดยการเพิ่มและแก้ไขคำสั่งในบรรทัดที่ 8 9 12 สังเกตจำนวนเวลาที่วนรอบ (อย่าลืมแก้ไขจำนวนรอบเป็นเพียง 10,000 รอบเท่านั้น มิฉะนั้นโปรแกรมอาจจะหยุดค้างได้) โดยเขียนโค้ดดังนี้

|1|  Imports System.Diagnostics
|2|  Public Class Form1
|3|      Private Sub Button1_Click(....) Handles Button1.Click
|4|          Dim objStopwatch As New Stopwatch
|5|          Dim i As Double
|6|          Dim s As String
|7|          objStopwatch.Start()
|8|          For i = 1 To 10000
|9|              s = s & "รักษ์เลย" & i & vbCrLf
|10|         Next
|11|         objStopwatch.Stop()
|12|         TextBox1.Text = s
|13|         MsgBox(objStopwatch.ElapsedMilliseconds)
|14|     End Sub
|15|  End Class
บรรทัดที่ 6 คือการประกาศตัวแปร S ชนิด String
บรรทัดที่ 9 คือการเชื่อมสตริงพร้อมตัดบรรทัดในทุกๆการวนรอบ
(4)  จากนั้นเมื่อรันโปรแกรมแล้วกดปุ่ม Test For จะมีการวนรอบคำว่า “รักษ์เลย” จำนวนหนึ่งหมึ่นแถวและแสดงจำนวนเวลาหน่วยเป็นมินลิวินาที ในที่นี้คือ 780 มินลิวินาที


(5)  หากนักศึกษาทดสอบการทำซ้ำจากหนึ่งหมื่นรอบเป็นหนึ่งแสนรอบจะเห็นการหยุดค้างของโปรแกรมในขณะที่ ซีพียูไม่สามารถประมวลผล Process อื่นได้ ด้วยปัญหานี้การเชื่อมสตริงโดยวิธีการทั่วไปจึงเกิดปัญหาเมื่อข้อมูลมีมากขึ้น ดังนั้น .NET จึงได้มีคลาส StringBuilder เพื่อแก้ปัญหาดังกล่าว


ความคิดเห็น

โพสต์ยอดนิยมจากบล็อกนี้

บทที่ 11 ตอน 3 การออกแบบรายงานด้วย Crystal Report

บทที่ 6 กระบวนการพอลิมอร์ฟิซึม (Polymorphism)

บทที่ 11 ตอน 3 การออกแบบรายงานด้วย Crystal Report Ex2