खोज…


परिचय

Ditger 2, जैसा कि GitHub पर समझाया गया है , निर्भरता इंजेक्शन के लिए एक संकलन-समय विकास दृष्टिकोण है। डैगर 1.x में शुरू किए गए दृष्टिकोण को अपने अंतिम निष्कर्ष तक ले जाना, डैगर 2.x सभी प्रतिबिंब को समाप्त करता है, और उपयोगकर्ता द्वारा निर्दिष्ट @Component इंटरफेस के पक्ष में पारंपरिक ObjectGraph / Injector को हटाकर कोड स्पष्टता में सुधार करता है।

टिप्पणियों

  1. आवेदन में लाइब्रेरी सेटअप (मावेन, ग्रेडेल, जावा परियोजनाओं के लिए)
  2. ड्रैगर उपयोग के लाभ
  3. महत्वपूर्ण लिंक (प्रलेखन और डेमो के लिए)
  4. ड्रैगर घटकों को कैसे एकीकृत और उपयोग करें

डैगर 2 एपीआई:

डैगर 2 कई विशेष एनोटेशन को उजागर करता है:

@ जिन वर्गों के तरीकों पर निर्भरता प्रदान की जाती है, उनके लिए नियमन

@Module कक्षाओं के भीतर तरीकों के लिए प्रदान करता है

@ एक निर्भरता का अनुरोध करने के लिए (एक निर्माता, एक क्षेत्र, या एक विधि)

@Component मॉड्यूल और इंजेक्शन के बीच एक ब्रिज इंटरफेस है

महत्वपूर्ण लिंक:

GitHub: https://github.com/google/dagger

UserGuide (Google): https://google.github.io/dagger/users-guide.html

वीडियो: https://google.github.io/dagger/resources.html

वोगेला ट्यूटोरियल: http://www.vogella.com/tutorials/Dagger/article.html

कोडपथ ट्यूटोरियल: https://github.com/codepath/android_guides/wiki/D dependency-Injection-with-Dagger-2

ऑब्जेक्ट के लिए @Module क्लास और @Singleton एनोटेशन बनाएं

import javax.inject.Singleton;
import dagger.Module;
import dagger.Provides;

@Module
public class VehicleModule {
 
    @Provides @Singleton
    Motor provideMotor(){
        return new Motor();
    }
 
    @Provides @Singleton
    Vehicle provideVehicle(){
        return new Vehicle(new Motor());
    }
}

हर प्रदाता (या विधि) के पास @Provides एनोटेशन होना चाहिए और क्लास के पास @Module एनोटेशन होना चाहिए। @Singleton एनोटेशन इंगित करता है कि ऑब्जेक्ट का केवल एक उदाहरण होगा।

आश्रित वस्तुओं में निर्भरता का अनुरोध करें

अब जब आपके पास अपने विभिन्न मॉडलों के लिए प्रदाता हैं, तो आपको उन्हें अनुरोध करने की आवश्यकता है। जिस प्रकार Vehicle को Motor आवश्यकता होती है, आपको Vehicle निर्माता में @Inject एनोटेशन को इस प्रकार जोड़ना होगा:

@Inject
public Vehicle(Motor motor){
    this.motor = motor;
}

आप कंस्ट्रक्टर, फ़ील्ड्स, या विधियों में निर्भरता का अनुरोध करने के लिए @Inject एनोटेशन का उपयोग कर सकते हैं। इस उदाहरण में, मैं कंस्ट्रक्टर में इंजेक्शन रख रहा हूं।

@Inject के साथ @Modules को कनेक्ट करना

निर्भरता के प्रदाता, @Module और @Inject माध्यम से उनसे अनुरोध करने वाली कक्षाओं के बीच का कनेक्शन @Inject का उपयोग करके बनाया @Component , जो एक इंटरफ़ेस है:

import javax.inject.Singleton;
import dagger.Component;

@Singleton
@Component(modules = {VehicleModule.class})
public interface VehicleComponent {
    Vehicle provideVehicle();
}

@Component एनोटेशन के लिए, आपको यह निर्दिष्ट करना होगा कि कौन से मॉड्यूल का उपयोग किया जा रहा है। इस उदाहरण में VehicleModule का उपयोग किया जाता है, जिसे इस उदाहरण में परिभाषित किया गया है । यदि आपको अधिक मॉड्यूल का उपयोग करने की आवश्यकता है, तो बस उन्हें विभाजक के रूप में अल्पविराम का उपयोग करके जोड़ें।

वस्तुओं को प्राप्त करने के लिए @Component इंटरफ़ेस का उपयोग करना

अब जब आपके पास हर कनेक्शन तैयार है, तो आपको इस इंटरफ़ेस का एक उदाहरण प्राप्त करना होगा और अपनी ज़रूरत की वस्तु प्राप्त करने के लिए इसके तरीकों को लागू करना होगा:

VehicleComponent component = Dagger_VehicleComponent.builder().vehicleModule(new VehicleModule()).build();
vehicle = component.provideVehicle();
Toast.makeText(this, String.valueOf(vehicle.getSpeed()), Toast.LENGTH_SHORT).show();

जब आप @Component एनोटेशन के साथ इंटरफ़ेस का एक नया ऑब्जेक्ट बनाने का प्रयास करते हैं, तो आपको यह करना होगा उपसर्ग Dagger_<NameOfTheComponentInterface> का उपयोग करके, इस मामले में Dagger_VehicleComponent , और उसके बाद हर मॉड्यूल को कॉल करने के लिए बिल्डर पद्धति का उपयोग करें।



Modified text is an extract of the original Stack Overflow Documentation
के तहत लाइसेंस प्राप्त है CC BY-SA 3.0
से संबद्ध नहीं है Stack Overflow