असाइनमेंट (कंप्यूटर विज्ञान)

कंप्यूटर प्रोग्रामिंग में, एक असाइनमेंट स्टेटमेंट एक चर (प्रोग्रामिंग) नाम द्वारा दर्शाए गए भंडारण स्थान (स्थानों) में संग्रहीत मूल्य (कंप्यूटर विज्ञान) को सेट या फिर से सेट करता है; दूसरे शब्दों में, यह एक मान को चर में कॉपी करता है। अधिकांश अनिवार्य प्रोग्रामिंग भाषाओं में, असाइनमेंट स्टेटमेंट (या एक्सप्रेशन) एक मौलिक निर्माण है।

आज, इस ऑपरेशन के लिए सबसे अधिक इस्तेमाल किया जाने वाला नोटेशन है  (मूल रूप से सुपरप्लान 1949-51, फोरट्रान 1957 और सी (प्रोग्रामिंग भाषा) द्वारा लोकप्रिय)। दूसरा सबसे अधिक इस्तेमाल किया जाने वाला संकेतन   (मूल रूप से ALGOL 1958, पास्कल (प्रोग्रामिंग भाषा) द्वारा लोकप्रिय) है। कई अन्य संकेतन भी उपयोग में हैं। कुछ भाषाओं में, प्रयुक्त प्रतीक को एक ऑपरेटर (प्रोग्रामिंग) के रूप में माना जाता है (जिसका अर्थ है कि असाइनमेंट स्टेटमेंट एक संपूर्ण मान देता है)। अन्य भाषाएँ असाइनमेंट को एक कथन के रूप में परिभाषित करती हैं (जिसका अर्थ है कि इसे किसी अभिव्यक्ति में उपयोग नहीं किया जा सकता है)।

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

शब्दार्थ
एक असाइनमेंट ऑपरेशन अनिवार्य प्रोग्रामिंग में एक प्रक्रिया है जिसमें समय बीतने के साथ अलग-अलग मान एक विशेष चर नाम से जुड़े होते हैं। इस तरह के मॉडल में कार्यक्रम लगातार असाइनमेंट स्टेटमेंट्स का उपयोग करके अपनी स्थिति को बदलकर संचालित होता है। अनिवार्य प्रोग्रामिंग भाषाओं के पुरातन पुनरावृति करने के लिए असाइनमेंट पर निर्भर करते हैं। निम्नतम स्तर पर,  या   जैसे मशीन संचालन का उपयोग करके असाइनमेंट कार्यान्वित किया जाता है।

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


 * कार्यक्रम की वर्तमान स्थिति में का मूल्यांकन किया जाता है।
 * को परिकलित मान निर्दिष्ट किया जाता है, जो उस चर के पूर्व मान को प्रतिस्थापित करता है।

उदाहरण: यह मानते हुए कि a एक संख्यात्मक चर है, असाइनमेंट  अर्थ है कि कथन के निष्पादन के बाद चर    की सामग्री दोगुनी हो जाती है।

सी (प्रोग्रामिंग भाषा) कोड का एक उदाहरण खंड:

<वाक्यविन्यास प्रकाश लैंग = सी>

इंट एक्स = 10;

फ्लोट वाई;

एक्स = 23; वाई = 32.4f;



इस नमूने में, चर  को पहले एक int के रूप में घोषित किया जाता है, और फिर इसे 10 का मान निर्दिष्ट किया जाता है। ध्यान दें कि घोषणा और असाइनमेंट एक ही कथन में होते हैं। दूसरी पंक्ति में,   बिना असाइनमेंट के घोषित किया जाता है। तीसरी पंक्ति में,   को 23 का मान पुन: असाइन किया गया है। अंत में,   को 32.4 का मान असाइन किया गया है।

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

एकल असाइनमेंट
कोई भी असाइनमेंट जो किसी मौजूदा मान को बदलता है (उदा। ) विशुद्ध रूप से कार्यात्मक प्रोग्रामिंग भाषाओं में अस्वीकृत है। कार्यात्मक प्रोग्रामिंग में, एकल असाइनमेंट के पक्ष में असाइनमेंट को हतोत्साहित किया जाता है, जिसे इनिशियलाइज़ेशन भी कहा जाता है। एकल असाइनमेंट नाम बाध्यकारी का एक उदाहरण है और इस आलेख में वर्णित असाइनमेंट से अलग है कि यह केवल एक बार किया जा सकता है, आमतौर पर जब वेरिएबल बनाया जाता है; किसी बाद के पुनर्मूल्यांकन की अनुमति नहीं है।

अभिव्यक्ति के मूल्यांकन का कोई साइड इफेक्ट नहीं होता है (कंप्यूटर विज्ञान) यदि यह मशीन की अवलोकन योग्य स्थिति को नहीं बदलता है, और समान इनपुट के लिए समान मान उत्पन्न करता है। अनिवार्य असाइनमेंट पुराने मूल्य को नष्ट करते समय साइड इफेक्ट्स पेश कर सकता है और इसे एक नए के साथ प्रतिस्थापित करते समय अनुपलब्ध कर सकता है, और इसे विनाशकारी अद्यतन के समान LISP और कार्यात्मक प्रोग्रामिंग में उस कारण के लिए विनाशकारी असाइनमेंट के रूप में संदर्भित किया जाता है।

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

अशुद्ध कार्यात्मक भाषाएँ एकल असाइनमेंट के साथ-साथ सही असाइनमेंट दोनों प्रदान करती हैं (हालाँकि सही असाइनमेंट आमतौर पर अनिवार्य प्रोग्रामिंग भाषाओं की तुलना में कम आवृत्ति के साथ उपयोग किया जाता है)। उदाहरण के लिए, योजना में, एकल असाइनमेंट और ट्रू असाइनमेंट  उदाहरण के लिए, योजना में, एकल असाइनमेंट (लेट के साथ) और ट्रू असाइनमेंट (सेट के साथ!) दोनों का उपयोग सभी चर पर किया जा सकता है, और सूचियों, वैक्टर, स्ट्रिंग्स आदि के अंदर विनाशकारी अद्यतन के लिए विशेष पुरातन प्रदान किए जाते हैं। OCaml में, चर के लिए केवल एक असाइनमेंट की अनुमति है,   सिंटैक्स के माध्यम से; हालांकि अलग-अलग  ऑपरेटर के साथ सरणी और तारों के तत्वों पर विनाशकारी अद्यतन का उपयोग किया जा सकता है, साथ ही रिकॉर्ड और ऑब्जेक्ट्स के क्षेत्रों पर भी प्रोग्रामर द्वारा स्पष्ट रूप से उत्परिवर्तनीय घोषित किया गया है (अर्थात् उनकी प्रारंभिक घोषणा के बाद परिवर्तित होने में सक्षम)।

एकल असाइनमेंट का उपयोग करने वाली कार्यात्मक प्रोग्रामिंग भाषाओं में क्लोजर (डेटा संरचनाओं के लिए, वर्र्स नहीं), एरलांग (प्रोग्रामिंग भाषा) शामिल हैं (हास्केल के विपरीत मान बराबर होने पर यह एकाधिक असाइनमेंट स्वीकार करता है), एफ शार्प (प्रोग्रामिंग भाषा) | एफ #, हास्केल (प्रोग्रामिंग लैंग्वेज), जावास्क्रिप्ट (स्थिरांक के लिए), लावा (प्रोग्रामिंग भाषा), OCaml, Oz (प्रोग्रामिंग लैंग्वेज) (डेटाफ्लो वेरिएबल्स के लिए, सेल नहीं), रैकेट (प्रोग्रामिंग भाषा) (कुछ डेटा स्ट्रक्चर्स जैसे लिस्ट के लिए, सिंबल नहीं) एसएएसएल (प्रोग्रामिंग लैंग्वेज), स्काला (प्रोग्रामिंग भाषा) (वैल्स के लिए), एक प्रकार का पौधा, मानक एमएल। गैर-बैक ट्रैकिंग प्रोलॉग कोड को स्पष्ट एकल-असाइनमेंट माना जा सकता है, इस अर्थ में स्पष्ट है कि इसके (नामित) चर स्पष्ट रूप से अनिर्दिष्ट अवस्था में हो सकते हैं, या ठीक एक बार सेट किए जा सकते हैं। हास्केल में, इसके विपरीत, कोई अनिर्दिष्ट चर नहीं हो सकता है, और प्रत्येक चर को निहित रूप से सेट होने के बारे में सोचा जा सकता है, जब इसे बनाया जाता है, इसके मूल्य (या बल्कि एक कम्प्यूटेशनल ऑब्जेक्ट के लिए जो मांग पर इसके मूल्य का उत्पादन करेगा)।

एक असाइनमेंट का मूल्य
कुछ प्रोग्रामिंग भाषाओं में, एक असाइनमेंट स्टेटमेंट एक मान लौटाता है, जबकि अन्य में ऐसा नहीं होता है।

अधिकांश अभिव्यक्ति-उन्मुख प्रोग्रामिंग भाषाओं में (उदाहरण के लिए, C (प्रोग्रामिंग भाषा)), असाइनमेंट स्टेटमेंट असाइन किए गए मान को लौटाता है, ऐसे मुहावरों को अनुमति देता है, जिसमें असाइनमेंट स्टेटमेंट   का मान लौटाता है  , जिसे बाद में सौंपा गया है. जैसे एक बयान में while ((ch = getchar) != EOF) {…}, किसी फ़ंक्शन के वापसी मान का उपयोग लूप को नियंत्रित करने के लिए किया जाता है जबकि उसी मान को एक चर के लिए निर्दिष्ट किया जाता है।

अन्य प्रोग्रामिंग भाषाओं में, योजना (प्रोग्रामिंग भाषा) उदाहरण के लिए, एक असाइनमेंट का वापसी मान अपरिभाषित है और ऐसे मुहावरे अमान्य हैं।

हास्केल (प्रोग्रामिंग भाषा) में, कोई चर असाइनमेंट नहीं है; लेकिन असाइनमेंट के समान संचालन (जैसे किसी सरणी के क्षेत्र या एक परिवर्तनीय डेटा संरचना के क्षेत्र को असाइन करना) आमतौर पर इकाई प्रकार का मूल्यांकन करता है, जिसे इस रूप में दर्शाया गया है. इस प्रकार का केवल एक संभावित मान है, इसलिए इसमें कोई जानकारी नहीं है। यह आम तौर पर एक अभिव्यक्ति का प्रकार है जिसका मूल्यांकन पूरी तरह से इसके दुष्प्रभावों के लिए किया जाता है।

असाइनमेंट के भिन्न रूप
कुछ उपयोग पैटर्न बहुत सामान्य हैं, और इस प्रकार अक्सर उनका समर्थन करने के लिए विशेष सिंटैक्स होते हैं। स्रोत कोड में अतिरेक को कम करने के लिए ये मुख्य रूप से सिंटैक्टिक चीनी हैं, लेकिन प्रोग्रामर के इरादे को समझने में कोड के पाठकों की सहायता भी करते हैं, और संकलक को संभावित अनुकूलन के लिए एक सुराग प्रदान करते हैं।

संवर्धित असाइनमेंट
मामला जहां असाइन किया गया मान पिछले एक पर निर्भर करता है, इतना सामान्य है कि कई अनिवार्य भाषाएं, विशेष रूप से सी (प्रोग्रामिंग भाषा) और इसके वंशजों में से अधिकांश, संवर्धित असाइनमेंट नामक विशेष ऑपरेटर प्रदान करते हैं, जैसे, इसलिए   के रूप में लिखा जा सकता है. सिंटैक्टिक चीनी से परे, यह चर के इन-प्लेस संशोधन को स्पष्ट करके संकलक के कार्य में सहायता करता है  संभव है।

जंजीर असाइनमेंट
जैसा कथन  एक जंजीर असाइनमेंट कहा जाता है जिसमें का मान   कई चरों को सौंपा गया है   और. जंजीर असाइनमेंट का उपयोग अक्सर कई चरों को आरंभ करने के लिए किया जाता है, जैसे कि

सभी प्रोग्रामिंग लैंग्वेज श्रृंखलित असाइनमेंट का समर्थन नहीं करती हैं। जंजीर असाइनमेंट असाइनमेंट के अनुक्रम के बराबर हैं, लेकिन मूल्यांकन की रणनीति भाषाओं के बीच भिन्न होती है। सरल जंजीर असाइनमेंट के लिए, जैसे कई चर प्रारंभ करना, मूल्यांकन रणनीति कोई मायने नहीं रखती है, लेकिन यदि असाइनमेंट में लक्ष्य (एल-वैल्यू) किसी तरह से जुड़े हुए हैं, तो मूल्यांकन रणनीति परिणाम को प्रभावित करती है।

कुछ प्रोग्रामिंग लैंग्वेज (उदाहरण के लिए C (प्रोग्रामिंग लैंग्वेज)) में, जंजीर असाइनमेंट समर्थित हैं क्योंकि असाइनमेंट एक्सप्रेशन हैं, और मान हैं। इस मामले में एक ऑपरेटर साहचर्य # राइट-एसोसिएटिविटी ऑफ़ असाइनमेंट ऑपरेटर्स | राइट-एसोसिएटिव असाइनमेंट, और असाइनमेंट राइट-टू-लेफ्ट होने से चेन असाइनमेंट को लागू किया जा सकता है। उदाहरण के लिए,  के बराबर है. सी ++ में वे असाइनमेंट ऑपरेटर के लिए उचित रिटर्न प्रकार घोषित करके वर्ग प्रकारों के मूल्यों के लिए भी उपलब्ध हैं।

पायथन (प्रोग्रामिंग लैंग्वेज) में, असाइनमेंट स्टेटमेंट एक्सप्रेशन नहीं हैं और इस प्रकार इसका कोई मूल्य नहीं है। इसके बजाय, जंजीर असाइनमेंट एक अभिव्यक्ति के लिए कई लक्ष्यों वाले बयानों की एक श्रृंखला है। असाइनमेंट बाएँ से दाएँ निष्पादित किए जाते हैं ताकि  अभिव्यक्ति का मूल्यांकन करता है , फिर परिणाम को सबसे बाएं लक्ष्य पर असाइन करता है,  , और फिर वही परिणाम अगले लक्ष्य को निर्दिष्ट करता है,  , के नए मान का उपयोग करना. यह अनिवार्य रूप से के बराबर है  हालांकि अस्थायी मूल्य के लिए कोई वास्तविक चर उत्पन्न नहीं होता है।

समानांतर असाइनमेंट
कुछ प्रोग्रामिंग लैंग्वेज, जैसे एपीएल (प्रोग्रामिंग भाषा), सामान्य लिस्प, जाओ (प्रोग्रामिंग भाषा), जावास्क्रिप्ट (1.7 के बाद से), पीएचपी, मेपल (सॉफ्टवेयर), लुआ (प्रोग्रामिंग भाषा), ओकम (प्रोग्रामिंग भाषा)#ओकम 2, पर्ल, पायथन (प्रोग्रामिंग भाषा), REBOL, रूबी (प्रोग्रामिंग भाषा), और PowerShell सिंटैक्स के साथ कई चर को समानांतर में असाइन करने की अनुमति देता है:

ए, बी: = 0, 1

जो एक साथ 0 को असाइन करता है  और 1 से. इसे अक्सर समांतर असाइनमेंट के रूप में जाना जाता है; इसे 1963 में CPL (प्रोग्रामिंग लैंग्वेज) में एक साथ असाइनमेंट के नाम से पेश किया गया था, और कभी-कभी इसे एकाधिक असाइनमेंट कहा जाता है, हालांकि यह भ्रमित करने वाला होता है जब एकल असाइनमेंट के साथ प्रयोग किया जाता है, क्योंकि ये विपरीत नहीं होते हैं। यदि असाइनमेंट का दाहिना भाग एक एकल चर (उदाहरण के लिए एक सरणी या संरचना) है, तो सुविधा को अनपैकिंग कहा जाता है या विनाशकारी असाइनमेंट: वार सूची := {0, 1} ए, बी: = सूची

सूची को अनपैक किया जाएगा ताकि 0 को असाइन किया जा सके  और 1 से. आगे,

ए, बी: = बी, ए

के मूल्यों की अदला-बदली करता है  और. समांतर असाइनमेंट के बिना भाषाओं में, इसे अस्थायी चर का उपयोग करने के लिए लिखा जाना होगा

वार टी := ए अ := ख ख := टी

तब से  दोनों छोड़ देता है   और   के मूल मूल्य के साथ.

कुछ भाषाएँ, जैसे कि गो और पायथन, समानांतर असाइनमेंट, ट्यूपल्स और स्वचालित b:Python Programming/Tuples#Packing and Unpacking को एक ही फ़ंक्शन से कई रिटर्न वैल्यू की अनुमति देने के लिए जोड़ती हैं, जैसा कि इस पायथन उदाहरण में है,

<वाक्यविन्यास लैंग = अजगर> डेफ एफ : वापसी 1, 2 ए, बी = एफ 

जबकि अन्य भाषाएँ, जैसे कि C शार्प (प्रोग्रामिंग लैंग्वेज) | C# और जंग (प्रोग्रामिंग भाषा), यहाँ दिखाई गई हैं, जिनमें कोष्ठकों के साथ स्पष्ट टपल निर्माण और विखंडन की आवश्यकता होती है:

<वाक्यविन्यास प्रकाश लैंग = csharp> // मान्य सी # या जंग सिंटैक्स (ए, बी) = (बी, ए); 

<वाक्यविन्यास प्रकाश लैंग = csharp> // सी # टपल वापसी (स्ट्रिंग, इंट) f => (फू, 1); वर (ए, बी) = च ; 

<वाक्यविन्यास प्रकाश लैंग = जंग> // रस्ट टपल रिटर्न चलो एफ = || (फू, 1); चलो (ए, बी) = एफ ; 

यह फ़ंक्शन से एकाधिक मान वापस करने के लिए आउटपुट पैरामीटर के उपयोग का विकल्प प्रदान करता है। यह CLU (प्रोग्रामिंग लैंग्वेज) (1974) की तारीख है, और CLU ने समानांतर असाइनमेंट को आम तौर पर लोकप्रिय बनाने में मदद की।

सी # अतिरिक्त रूप से दाहिने हाथ की ओर अभिव्यक्ति द्वारा परिभाषित कार्यान्वयन के साथ सामान्यीकृत डिकंस्ट्रक्शन असाइनमेंट की अनुमति देता है, क्योंकि संकलक एक उपयुक्त उदाहरण विधि या विस्तार विधि की खोज करता है  अभिव्यक्ति पर विधि, जिसमें वेरिएबल्स को असाइन किए जाने के लिए आउटपुट पैरामीटर होना चाहिए। उदाहरण के लिए, एक ऐसी विधि जो कक्षा (कंप्यूटर प्रोग्रामिंग) को देगी, वह उसी व्यवहार में दिखाई देगी जैसे वापसी मूल्य   ऊपर होगा <वाक्यविन्यास प्रकाश लैंग = csharp> शून्य डिकंस्ट्रक्ट (आउट स्ट्रिंग ए, आउट इंट बी) {ए = फू; बी = 1; } 

C और C++ में, अल्पविराम संचालिका समानांतर असाइनमेंट के समान है, जिससे एक ही स्टेटमेंट में कई असाइनमेंट होने की अनुमति मिलती है, राइटिंग  के बजाय. यह मुख्य रूप से कॉमा ऑपरेटर#फॉर लूप्स में उपयोग किया जाता है, और इसे गो जैसी अन्य भाषाओं में समानांतर असाइनमेंट द्वारा प्रतिस्थापित किया जाता है। हालांकि, उपरोक्त सी ++ कोड निम्नलिखित कोड के दाहिने तरफ से सही समानता सुनिश्चित नहीं करता है  बाईं ओर के बाद मूल्यांकन किया जाता है। पायथन जैसी भाषाओं में,   नए बी की गणना करने के लिए ए के प्रारंभिक मूल्य का उपयोग करके समवर्ती रूप से दो चर निर्दिष्ट करेगा।

असाइनमेंट बनाम समानता
बराबर के चिन्ह का प्रयोग  समानता के लिए तुलना के रूप में समान के साथ संघर्ष के कारण असाइनमेंट ऑपरेटर के रूप में अक्सर आलोचना की गई है। इसके परिणामस्वरूप लेखन कोड में नौसिखियों द्वारा भ्रम पैदा होता है, और कोड पढ़ने में अनुभवी प्रोग्रामरों द्वारा भी भ्रम होता है। समनुदेशन के लिए बराबरी का उपयोग हेंज रुतिशौसर की भाषा सुपरप्लान से शुरू होता है, जिसे 1949 से 1951 तक डिजाइन किया गया था, और विशेष रूप से फोरट्रान द्वारा लोकप्रिय किया गया था: "A notorious example for a bad idea was the choice of the equal sign to denote assignment. It goes back to Fortran in 1957 and has blindly been copied by armies of language designers. Why is it a bad idea? Because it overthrows a century old tradition to let “=” denote a comparison for equality, a predicate which is either true or false. But Fortran made it to mean assignment, the enforcing of equality. In this case, the operands are on unequal footing: The left operand (a variable) is to be made equal to the right operand (an expression). x = y does not mean the same thing as y = x." शुरुआती प्रोग्रामर कभी-कभी असाइनमेंट को समानता के लिए रिलेशनल ऑपरेटर के साथ भ्रमित कर देते हैं, जैसा कि = गणित में समानता (गणित) का मतलब है, और कई भाषाओं में असाइनमेंट के लिए उपयोग किया जाता है। लेकिन असाइनमेंट एक चर के मान को बदल देता है, जबकि समानता परीक्षण परीक्षण करता है कि क्या दो भावों का मूल्य समान है।

कुछ भाषाओं में, जैसे कि बुनियादी, एक बराबर चिह्न का उपयोग असाइनमेंट ऑपरेटर और समानता संबंधपरक ऑपरेटर दोनों के लिए किया जाता है, जिसका अर्थ संदर्भ निर्धारित करना है। अन्य भाषाएं दो ऑपरेटरों के लिए अलग-अलग प्रतीकों का उपयोग करती हैं। उदाहरण के लिए:


 * ALGOL और पास्कल (प्रोग्रामिंग लैंग्वेज) में, असाइनमेंट ऑपरेटर एक कोलन और एक बराबर का चिह्न जबकि समानता संकारक एकल बराबर है.
 * C (प्रोग्रामिंग लैंग्वेज) में, असाइनमेंट ऑपरेटर एक सिंगल इक्वल साइन जबकि समानता ऑपरेटर बराबर चिह्नों की एक जोड़ी है.
 * R (प्रोग्रामिंग लैंग्वेज) में, असाइनमेंट ऑपरेटर मूल रूप से होता है, के रूप में  , लेकिन कुछ संदर्भों में एकल बराबर चिह्न का उपयोग किया जा सकता है।

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

नोटेशन
कॉपी करने के असाइनमेंट के लिए दो सबसे आम प्रतिनिधित्व बराबर चिह्न हैं और कोलन-बराबर. भाषा और/या उपयोग के आधार पर दोनों रूपों को या तो असाइनमेंट स्टेटमेंट या असाइनमेंट ऑपरेटर (प्रोग्रामिंग) (जिसका मूल्य भी है) को शब्दार्थ रूप से निरूपित किया जा सकता है।
 * {| class="wikitable"

अन्य संभावनाओं में एक बायां तीर या एक कीवर्ड शामिल है, हालांकि अन्य, दुर्लभ, वेरिएंट हैं:
 * || Fortran, PL/I, C (and descendants such as C++, Java, etc.), Bourne shell, Python, Go (assignment to pre-declared variables), R, PowerShell, Nim, etc.
 * || ALGOL (and derivatives), Simula, CPL, BCPL, Pascal (and descendants such as Modula), Mary, PL/M, Ada, Smalltalk, Eiffel, Oberon, Dylan, Seed7, Python (an assignment expression), Go (shorthand for declaring and defining a variable), Io, AMPL, ML (assigning to a reference value), AutoHotkey etc.
 * }
 * || ALGOL (and derivatives), Simula, CPL, BCPL, Pascal (and descendants such as Modula), Mary, PL/M, Ada, Smalltalk, Eiffel, Oberon, Dylan, Seed7, Python (an assignment expression), Go (shorthand for declaring and defining a variable), Io, AMPL, ML (assigning to a reference value), AutoHotkey etc.
 * }
 * }


 * {| class="wikitable"

गणितीय स्यूडोकोड # सामान्य गणितीय प्रतीकों के असाइनमेंट को आम तौर पर बाएं-तीर के साथ दर्शाया जाता है।
 * || Magik
 * || F#, OCaml, R, S
 * || R
 * || R
 * || APL, Smalltalk, BASIC Programming
 * || J
 * || BASIC
 * || XQuery
 * || AppleScript
 * || C shell
 * || PowerShell
 * || Macsyma, Maxima, K
 * || Rebol
 * || mIRC scripting language
 * || Simula
 * }
 * || AppleScript
 * || C shell
 * || PowerShell
 * || Macsyma, Maxima, K
 * || Rebol
 * || mIRC scripting language
 * || Simula
 * }
 * || Rebol
 * || mIRC scripting language
 * || Simula
 * }
 * || Simula
 * }
 * }

कुछ प्लेटफ़ॉर्म अभिव्यक्ति को बाईं ओर और चर को दाईं ओर रखते हैं:


 * {| class="wikitable"

कुछ अभिव्यक्ति-उन्मुख भाषाएँ, जैसे लिस्प (प्रोग्रामिंग भाषा) और टीसीएल, समान रूप से असाइनमेंट सहित सभी बयानों के लिए उपसर्ग (या पोस्टफिक्स) सिंटैक्स का उपयोग करें।
 * style="padding-right: 1em" |  || COBOL
 * style="padding-right: 1em" |  || TI-BASIC, Casio BASIC
 * style="padding-right: 1em" |  || POP-2, BETA, R
 * style="padding-right: 1em" |  || LiveCode
 * style="padding-right: 1em" |  || ABC
 * }
 * style="padding-right: 1em" |  || LiveCode
 * style="padding-right: 1em" |  || ABC
 * }
 * style="padding-right: 1em" |  || ABC
 * }


 * {| class="wikitable"


 * style="padding-right: 1em" |  || Common Lisp
 * || Scheme
 * || Tcl
 * style="padding-right: 1em" |  || Forth
 * }
 * || Tcl
 * style="padding-right: 1em" |  || Forth
 * }
 * }

यह भी देखें

 * सी ++ में असाइनमेंट ऑपरेटर
 * ऑपरेटर (प्रोग्रामिंग)
 * नाम बंधन
 * एकीकरण (कम्प्यूटिंग)
 * अपरिवर्तनीय वस्तु
 * कॉन्स्ट-शुद्धता