तोता - रजिस्टर
वर्तमान पर्ल 5 वर्चुअल मशीन एक स्टैक मशीन है। यह उन्हें स्टैक पर रखकर संचालन के बीच मूल्यों का संचार करता है। स्टैक पर संचालन मानों को लोड करने के लिए उन्हें जो कुछ भी करने की आवश्यकता होती है उसे करें और परिणाम को स्टैक पर वापस रखें। इसके साथ काम करना आसान है, लेकिन यह धीमा है।
दो संख्याओं को एक साथ जोड़ने के लिए, आपको तीन स्टैक पुश और दो स्टैक पॉप करने की आवश्यकता है। इससे भी बदतर, स्टैक को रनटाइम पर बढ़ना है, और इसका मतलब है कि स्मृति को आवंटित करना जब आप इसे आवंटित नहीं करना चाहते हैं।
तो तोता आभासी मशीनों के लिए स्थापित परंपरा को तोड़ने जा रहा है, और एक रजिस्टर आर्किटेक्चर का उपयोग करता है, एक वास्तविक हार्डवेयर सीपीयू की वास्तुकला के लिए अधिक समान है। इसका एक और फायदा है। हम अपने सॉफ्टवेयर CPU के लिए रजिस्टर-आधारित CPU के लिए कंपाइलर और ऑप्टिमाइज़र लिखने के लिए सभी मौजूदा साहित्य का उपयोग कर सकते हैं!
तोते के प्रत्येक प्रकार के लिए विशेषज्ञ रजिस्टर होते हैं: 32 IV रजिस्टर, 32 एनवी रजिस्टर, 32 स्ट्रिंग रजिस्टर और 32 पीएमसी रजिस्टर। तोता असेंबलर में, इनका नाम क्रमशः I1 ... I32, N1 ... N32, S1 ... S32, P1 ... 3: 32 है।
अब आइए कुछ असेंबलर को देखें। हम इन रजिस्टरों को सेट ऑपरेटर के साथ सेट कर सकते हैं:
set I1, 10
set N1, 3.1415
set S1, "Hello, Parrot"
सभी तोता ऑप्स का एक ही प्रारूप है: ऑपरेटर का नाम, गंतव्य रजिस्टर और फिर ऑपरेंड।