जावा वर्चुअल मशीन - JIT ऑप्टिमाइज़ेशन

इस अध्याय में, हम JIT ऑप्टिमाइज़ेशन के बारे में जानेंगे।

विधि Inlining

इस अनुकूलन तकनीक में, कंपाइलर आपके फ़ंक्शन कॉल को फ़ंक्शन बॉडी से बदलने का निर्णय लेता है। नीचे उसी के लिए एक उदाहरण दिया गया है -

int sum3;

static int add(int a, int b) {
   return a + b;
}

public static void main(String…args) {
   sum3 = add(5,7) + add(4,2);
}

//after method inlining
public static void main(String…args) {
   sum3 = 5+ 7 + 4 + 2;
}

इस तकनीक का उपयोग करते हुए, कंपाइलर मशीन को किसी भी फंक्शन कॉल करने के ओवरहेड से बचाता है (इसमें स्टैक के लिए पुशिंग और पॉपिंग पैरामीटर की आवश्यकता होती है)। इस प्रकार, उत्पन्न कोड तेजी से चलता है।

विधि इनलाइनिंग केवल गैर-वर्चुअल फ़ंक्शंस के लिए किया जा सकता है (ऐसे कार्य जो ओवरराइड नहीं होते हैं)। विचार करें कि यदि उप-वर्ग में 'ऐड' पद्धति को ओवर-राइड किया जाता है और रनटाइम तक विधि युक्त ऑब्जेक्ट का प्रकार ज्ञात नहीं होता है। इस मामले में, संकलक को यह नहीं पता होगा कि इनलाइन किस पद्धति का है। लेकिन अगर विधि को 'अंतिम' के रूप में चिह्नित किया गया था, तो संकलक को आसानी से पता चल जाएगा कि यह इनलाइन हो सकता है क्योंकि यह किसी भी उप-वर्ग द्वारा ओवर-राइड नहीं किया जा सकता है। ध्यान दें कि यह बिल्कुल गारंटी नहीं है कि एक अंतिम विधि हमेशा लाइन में रहेगी।

अगम्य और मृत कोड उन्मूलन

अगम्य कोड वह कोड है जिसे किसी भी संभावित निष्पादन प्रवाह द्वारा नहीं पहुँचा जा सकता है। हम निम्नलिखित उदाहरण पर विचार करेंगे -

void foo() {
   if (a) return;
   else return;
   foobar(a,b); //unreachable code, compile time error
}

डेड कोड भी पहुंच से बाहर का कोड है, लेकिन कंपाइलर इस मामले में एक त्रुटि करता है। इसके बजाय, हमें सिर्फ एक चेतावनी मिलती है। कोड के प्रत्येक ब्लॉक जैसे कि कंस्ट्रक्टर, फ़ंक्शंस, कोशिश, कैच, अगर, जबकि, आदि, जेएलएस (जावा भाषा विनिर्देश) में परिभाषित अगम्य कोड के लिए अपने स्वयं के नियम हैं।

लगातार तह

निरंतर तह अवधारणा को समझने के लिए, नीचे दिया गया उदाहरण देखें।

final int num = 5;
int b = num * 6; //compile-time constant, num never changes
//compiler would assign b a value of 30.