tutorial PHP में::(डबल कॉलन) और->(तीर) के बीच क्या अंतर है?




php भाषा (5)

PHP में विधियों तक पहुंचने के दो अलग-अलग तरीके हैं, लेकिन क्या अंतर है?

$response->setParameter('foo', 'bar');

तथा

sfConfig::set('foo', 'bar');

मुझे लगता है -> (साइन या शेवरॉन से अधिक के साथ डैश) चर के लिए कार्यों के लिए प्रयोग किया जाता है, और :: (डबल कोलोन) कक्षाओं के कार्यों के लिए उपयोग किया जाता है। सही बात?

क्या => असाइनमेंट ऑपरेटर केवल सरणी के भीतर डेटा असाइन करने के लिए उपयोग किया जाता है? क्या यह = असाइनमेंट ऑपरेटर के विपरीत है जिसका प्रयोग चर को त्वरित या संशोधित करने के लिए किया जाता है?


जब बायां हिस्सा एक ऑब्जेक्ट उदाहरण होता है, तो आप -> उपयोग करते हैं। अन्यथा, आप :: उपयोग करें।

इसका मतलब है कि -> ज्यादातर उदाहरण सदस्यों तक पहुंचने के लिए उपयोग किया जाता है (हालांकि इसका उपयोग स्थिर सदस्यों तक पहुंचने के लिए भी किया जा सकता है, ऐसे उपयोग को हतोत्साहित किया जाता है), जबकि :: आमतौर पर स्थिर सदस्यों तक पहुंचने के लिए उपयोग किया जाता है (हालांकि कुछ विशेष मामलों में, इसका उपयोग किया जाता है उदाहरण सदस्यों तक पहुंचने के लिए)।

सामान्य रूप से, :: स्कोप रिज़ॉल्यूशन के लिए उपयोग किया जाता है, और इसमें या तो कक्षा का नाम, parent , self , या (PHP 5.3 में) static हो सकता है। parent उस वर्ग के सुपरक्लास के दायरे को संदर्भित करता है जहां इसका उपयोग किया जाता है; self उस वर्ग के दायरे को संदर्भित करता है जहां इसका उपयोग किया जाता है; static "कॉल स्कोप" को संदर्भित करता है ( देर से स्थिर बाइंडिंग देखें)।

नियम यह है कि :: साथ एक कॉल एक उदाहरण कॉल है अगर केवल अगर:

  • लक्ष्य विधि स्थिर और घोषित नहीं की जाती है
  • कॉल के समय एक संगत ऑब्जेक्ट संदर्भ है, जिसका अर्थ है कि ये सत्य होना चाहिए:
    1. कॉल एक संदर्भ से बना है जहां $this मौजूद है और
    2. $this की कक्षा या तो इसे बुलाया जाने वाला तरीका या इसके उप-वर्ग का वर्ग है।

उदाहरण:

class A {
    public function func_instance() {
        echo "in ", __METHOD__, "\n";
    }
    public function callDynamic() {
        echo "in ", __METHOD__, "\n";
        B::dyn();
    }

}

class B extends A {
    public static $prop_static = 'B::$prop_static value';
    public $prop_instance = 'B::$prop_instance value';

    public function func_instance() {
        echo "in ", __METHOD__, "\n";
        /* this is one exception where :: is required to access an
         * instance member.
         * The super implementation of func_instance is being
         * accessed here */
        parent::func_instance();
        A::func_instance(); //same as the statement above
    }

    public static function func_static() {
        echo "in ", __METHOD__, "\n";
    }

    public function __call($name, $arguments) {
        echo "in dynamic $name (__call)", "\n";
    }

    public static function __callStatic($name, $arguments) {
        echo "in dynamic $name (__callStatic)", "\n";
    }

}

echo 'B::$prop_static: ', B::$prop_static, "\n";
echo 'B::func_static(): ', B::func_static(), "\n";
$a = new A;
$b = new B;
echo '$b->prop_instance: ', $b->prop_instance, "\n";
//not recommended (static method called as instance method):
echo '$b->func_static(): ', $b->func_static(), "\n";

echo '$b->func_instance():', "\n", $b->func_instance(), "\n";

/* This is more tricky
 * in the first case, a static call is made because $this is an
 * instance of A, so B::dyn() is a method of an incompatible class
 */
echo '$a->dyn():', "\n", $a->callDynamic(), "\n";
/* in this case, an instance call is made because $this is an
 * instance of B (despite the fact we are in a method of A), so
 * B::dyn() is a method of a compatible class (namely, it's the
 * same class as the object's)
 */
echo '$b->dyn():', "\n", $b->callDynamic(), "\n";

आउटपुट:

B::$prop_static: B::$prop_static value
B::func_static(): in B::func_static

$b->prop_instance: B::$prop_instance value
$b->func_static(): in B::func_static

$b->func_instance():
in B::func_instance
in A::func_instance
in A::func_instance

$a->dyn():
in A::callDynamic
in dynamic dyn (__callStatic)

$b->dyn():
in A::callDynamic
in dynamic dyn (__call)

स्थैतिक और तत्काल विधियों और गुणों के बीच का अंतर PHP 5 में ओओपी PHP के साथ शुरू करने वालों के लिए सबसे बड़ी बाधाओं में से एक प्रतीत होता है।

दोहरे कोलन ऑपरेटर (जिसे हिब्रू - पायविया से पामायम नेकुडोटायम कहा जाता है) का उपयोग किसी ऑब्जेक्ट या संपत्ति को स्थिर संदर्भ से कॉल करते समय किया जाता है। इसका मतलब है कि ऑब्जेक्ट का एक उदाहरण अभी तक नहीं बनाया गया है।

तीर ऑपरेटर, इसके विपरीत, ऑब्जेक्ट के उदाहरण के संदर्भ से विधियों या गुणों को कॉल करता है।

स्टेटिक विधियां ऑब्जेक्ट मॉडल में विशेष रूप से उपयोगी हो सकती हैं जो विधियों को बनाने और हटाने के लिए डेटाबेस से जुड़ी हैं, क्योंकि आप वापसी मूल्य आईडी पर वापसी मान सेट कर सकते हैं और फिर पंक्ति आईडी द्वारा ऑब्जेक्ट को तुरंत चालू करने के लिए कन्स्ट्रक्टर का उपयोग कर सकते हैं।


:: स्थिर संदर्भ में प्रयोग किया जाता है, यानी। जब कुछ विधि या संपत्ति को स्थैतिक घोषित किया जाता है:

class Math {
    public static function sin($angle) {
        return ...;
    }
}

$result = Math::sin(123);

इसके अलावा, :: ऑपरेटर (स्कोप रेज़ोल्यूशन ऑपरेटर, उर्फ पामायम नेकुडोटायम ) गतिशील संदर्भ में उपयोग किया जाता है जब आप अभिभावक वर्ग की विधि / संपत्ति का आह्वान करते हैं:

class Rectangle {
     protected $x, $y;

     public function __construct($x, $y) {
         $this->x = $x;
         $this->y = $y;
     }
}

class Square extends Rectangle {
    public function __construct($x) {
        parent::__construct($x, $x);
    }
}

-> गतिशील संदर्भ में प्रयोग किया जाता है, यानी। जब आप कुछ वर्ग के कुछ उदाहरण से निपटते हैं:

class Hello {
    public function say() {
       echo 'hello!';
    }
}

$h = new Hello();
$h->say();

वैसे: मुझे नहीं लगता कि सिम्फनी का उपयोग करना एक अच्छा विचार है जब आपके पास कोई ओओपी अनुभव नहीं है।


=> ऑपरेटर का उपयोग एक एसोसिएटिव सरणी में कुंजी-मूल्य जोड़े असाइन करने के लिए किया जाता है। उदाहरण के लिए:

$fruits = array(
  'Apple'  => 'Red',
  'Banana' => 'Yellow'
);

इसका अर्थ foreach कथन में समान है:

foreach ($fruits as $fruit => $color)
  echo "$fruit is $color in color.";

असल में इस प्रतीक से हम एक क्लास विधि को कॉल कर सकते हैं जो स्थैतिक है और अन्य प्रारंभिकरण पर निर्भर नहीं है ...

class Test {

    public $name;

    public function __construct() {
        $this->name = 'Mrinmoy Ghoshal';
    }

    public static function doWrite($name) {
        print 'Hello '.$name;
    }

    public function write() {
        print $this->name;
    }
}

यहां doWrite () फ़ंक्शन किसी अन्य विधि या चर पर निर्भर नहीं है, और यह एक स्थिर विधि है। यही कारण है कि हम इस वर्ग के ऑब्जेक्ट को शुरू किए बिना इस विधि को इस ऑपरेटर द्वारा क्यों कॉल कर सकते हैं।

Test::doWrite('Mrinmoy'); // Output: Hello Mrinmoy.

लेकिन अगर आप इस तरह से write विधि को कॉल करना चाहते हैं, तो यह एक त्रुटि उत्पन्न करेगा क्योंकि यह प्रारंभिकरण पर निर्भर है।







php