Visual Basic for Applications:
रीफैक्टरिंग
कैसे:
विजुअल बेसिक फॉर एप्लिकेशन्स (VBA) में एक बुनियादी उदाहरण पर विचार करें जहाँ हमारे पास एक कर्मचारी के विवरण को प्रिंट करने वाली एक सबरूटीन है। प्रारंभ में, कोड अव्यवस्थित होता है, इसे बनाए रखना या विस्तार करना चुनौतीपूर्ण होता है।
Sub PrintEmployeeDetails()
Dim name As String
Dim age As Integer
Dim department As String
name = "John Doe"
age = 30
department = "IT"
MsgBox "Name: " & name & vbCrLf & "Age: " & age & vbCrLf & "Department: " & department
End Sub
रिफैक्टरिंग चरण 1: मेथड निकालें। सबसे आम रिफैक्टरिंग तकनीकों में से एक कोड के एक विशिष्ट भाग को लेना और इसे अपने मेथड में ले जाना है। यह कोड को अधिक मॉड्यूलर और समझने में आसान बनाता है।
Sub PrintEmployeeDetails()
Dim name As String
Dim age As Integer
Dim department As String
name = "John Doe"
age = 30
department = "IT"
DisplayMessage name, age, department
End Sub
Private Sub DisplayMessage(name As String, age As Integer, department As String)
MsgBox "Name: " & name & vbCrLf & "Age: " & age & vbCrLf & "Department: " & department
End Sub
रिफैक्टरिंग चरण 2: एक संरचना का उपयोग करें। यह चरण एक डेटा संरचना का उपयोग करते हुए शामिल है जो संबंधित डेटा को धारण करता है, कोड की स्पष्टता में सुधार करता है और समूहित डेटा को चारों ओर पास करने में आसान बनाता है।
Type Employee
name As String
age As Integer
department As String
End Type
Sub PrintEmployeeDetails()
Dim emp As Employee
emp.name = "John Doe"
emp.age = 30
emp.department = "IT"
DisplayMessage emp
End Sub
Private Sub DisplayMessage(emp As Employee)
MsgBox "Name: " & emp.name & vbCrLf & "Age: " & emp.age & vbCrLf & "Department: " & emp.department
End Sub
ये चरण अव्यवस्थित कोड को मॉड्यूलर, संरचित कोड में परिवर्तित करते हैं, जो पठनीयता और रखरखाव में काफी सुधार करते हैं।
गहराई में
रिफैक्टरिंग की अवधारणा जितनी पुरानी है उतनी ही प्रोग्रामिंग है, लेकिन मार्टिन फॉव�र� की पुस्तक “रिफैक्टरिंग: इम्प्रूविंग द डिज़ाइन ऑफ़ एक्ज़िस्टिंग कोड” ने इसे मुख्यधारा में लाया, जिसने सॉफ्टवेयर विकास प्रक्रिया में इसके महत्व पर जोर दिया। विजुअल बेसिक फॉर एप्लिकेशन्स में, रिफैक्टरिंग कुछ अधिक चुनौतीपूर्ण हो सकती है क्योंकि इसमें आधुनिक इंटीग्रेटेड डेवलपमेंट वातावरणों (IDEs) में पाए जाने वाले स्वचालित रिफैक्टरिंग का समर्थन करने वाले निर्मित उपकरणों की कमी होती है।
हालांकि, इससे इसका महत्व कम नहीं होता है। VBA में भी, मैन्युअल रूप से बुनियादी रिफैक्टरिंग तकनीकों को लागू करने से कोड बेस में काफी हद तक सुधार होता है, जिससे यह साफ और अधिक कुशल हो जाता है। जबकि VBA में आधुनिक सुविधाओं की उसी तरह की उपलब्धता नहीं हो सकती है, अच्छे कोड डिज़ाइन के सिद्धांत सार्वभौमिक रहते हैं। अन्य भाषाओं से आने वाले डेवलपर्स को मैन्युअल प्रक्रिया थकाऊ मिल सकती है लेकिन कोड गुणवत्ता में सुधार करने में समय निवेश करने के लाभों की सराहना नि�श्चित रूप से करेंगे।
अधिक मजबूत विकास वातावरणों के लिए या विशेष रूप से जटिल परियोजनाओं पर काम करते समय, अधिक शक्तिशाली रिफैक्टरिंग उपकरणों की पेशकश करने वाले विकल्पों का पता लगाना या VBA परियोजनाओं को .NET भाषा में परिवर्तित करना जहां विजुअल स्टूडियो व्यापक रिफैक्टरिंग समर्थन प्रदान करता है, लायक हो सकता है। फिर भी, VBA में रिफैक्टरिंग सिद्धांतों को समझना और लागू करना एक मूल्यवान कौशल है जो साफ, रखरखाव योग्य कोड लिखने के महत्व को उजागर करता है, चाहे वातावरण कोई भी हो।