प्रोग्रामिंग के तरीके - त्वरित गाइड

जब इन्वेंट्री प्रबंधन, पेरोल प्रोसेसिंग, छात्र प्रवेश, परीक्षा परिणाम प्रसंस्करण आदि जैसे वास्तविक जीवन की समस्याओं को हल करने के लिए कार्यक्रम विकसित किए जाते हैं, तो वे विशाल और जटिल हो जाते हैं। ऐसी जटिल समस्याओं का विश्लेषण करने, सॉफ्टवेयर विकास की योजना बनाने और विकास प्रक्रिया को नियंत्रित करने के दृष्टिकोण को कहा जाता हैprogramming methodology

प्रोग्रामिंग के तरीके

सॉफ्टवेयर डेवलपर्स के बीच प्रचलित कई तरह की प्रोग्रामिंग पद्धतियां हैं -

प्रक्रियात्मक प्रोग्रामिंग

समस्या प्रक्रियाओं में टूट गई है, या कोड के ब्लॉक जो प्रत्येक कार्य को करते हैं। एक साथ ली गई सभी प्रक्रियाएं पूरे कार्यक्रम का निर्माण करती हैं। यह केवल छोटे कार्यक्रमों के लिए उपयुक्त है जिनमें जटिलता का स्तर कम है।

Example- एक कैलकुलेटर प्रोग्राम के लिए जो जोड़, घटाव, गुणा, भाग, वर्गमूल और तुलना करता है, इनमें से प्रत्येक ऑपरेशन को अलग-अलग प्रक्रियाओं के साथ विकसित किया जा सकता है। मुख्य कार्यक्रम में प्रत्येक प्रक्रिया को उपयोगकर्ता की पसंद के आधार पर लागू किया जाएगा।

ऑब्जेक्ट ओरिएंटेड प्रोग्रामिंग

यहां समाधान संस्थाओं या वस्तुओं के आसपास घूमता है जो समस्या का हिस्सा हैं। समाधान यह बताता है कि संस्थाओं से संबंधित डेटा को कैसे संग्रहीत किया जाए, संस्थाएं कैसे व्यवहार करती हैं और कैसे वे एक दूसरे के साथ मिलकर एक समाधान बनाते हैं।

Example - अगर हमें पेरोल मैनेजमेंट सिस्टम विकसित करना है, तो हमारे पास कर्मचारी, वेतन संरचना, अवकाश नियम आदि होंगे, जिनके चारों ओर समाधान बनाया जाना चाहिए।

कार्यात्मक प्रोग्रामिंग

यहां समस्या, या वांछित समाधान, कार्यात्मक इकाइयों में टूट गया है। प्रत्येक इकाई अपना कार्य स्वयं करती है और आत्मनिर्भर है। इन इकाइयों को फिर पूरा समाधान बनाने के लिए एक साथ सिला जाता है।

Example - पेरोल प्रोसेसिंग में कार्यात्मक इकाइयाँ हो सकती हैं जैसे कर्मचारी डेटा रखरखाव, मूल वेतन गणना, सकल वेतन गणना, अवकाश प्रसंस्करण, ऋण चुकौती प्रसंस्करण आदि।

तार्किक प्रोग्रामिंग

यहां समस्या कार्यात्मक इकाइयों के बजाय तार्किक इकाइयों में टूट गई है। Example:एक स्कूल प्रबंधन प्रणाली में, उपयोगकर्ताओं के पास कक्षा शिक्षक, विषय शिक्षक, प्रयोगशाला सहायक, समन्वयक, शैक्षणिक प्रभारी आदि जैसे बहुत परिभाषित भूमिकाएं होती हैं, इसलिए सॉफ्टवेयर को उपयोगकर्ता भूमिकाओं के आधार पर इकाइयों में विभाजित किया जा सकता है। प्रत्येक उपयोगकर्ता के पास अलग-अलग इंटरफ़ेस, अनुमतियां आदि हो सकती हैं।

सॉफ्टवेयर डेवलपर्स एक सॉफ्टवेयर विकसित करने के लिए इनमें से एक से अधिक कार्यप्रणाली का एक या एक संयोजन चुन सकते हैं। ध्यान दें कि चर्चा की गई प्रत्येक पद्धति में, समस्या को छोटी इकाइयों में तोड़ना पड़ता है। ऐसा करने के लिए, डेवलपर्स निम्नलिखित दो दृष्टिकोणों में से किसी का उपयोग करते हैं -

  • शीर्ष पाद उपागम
  • नीचे से ऊपर का दृष्टिकोण

टॉप-डाउन या मॉड्यूलर दृष्टिकोण

समस्या छोटी इकाइयों में टूट जाती है, जिसे आगे छोटी इकाइयों में भी तोड़ा जा सकता है। प्रत्येक इकाई को एक कहा जाता हैmodule। प्रत्येक मॉड्यूल एक आत्मनिर्भर इकाई है जिसके पास अपना कार्य करने के लिए आवश्यक सब कुछ है।

निम्नलिखित चित्रण एक उदाहरण दिखाता है कि आप पेरोल प्रोसेसिंग प्रोग्राम को विकसित करते समय विभिन्न मॉड्यूल बनाने के लिए मॉड्यूलर दृष्टिकोण का पालन कैसे कर सकते हैं।

नीचे से ऊपर का दृष्टिकोण

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

आइए हम एक कैलकुलेटर प्रोग्राम के घटकों को देखें।

एक विशिष्ट सॉफ्टवेयर विकास प्रक्रिया इन चरणों का पालन करती है -

  • आवश्यक भीड़ जुटना
  • समस्या की परिभाषा
  • प्रणाली की रूपरेखा
  • Implementation
  • Testing
  • Documentation
  • प्रशिक्षण और समर्थन
  • Maintenance

पहले दो चरण समस्या को समझने में टीम की सहायता करते हैं, एक समाधान प्राप्त करने की दिशा में सबसे महत्वपूर्ण पहला कदम। आवश्यकता को इकट्ठा करने, समस्या को परिभाषित करने और प्रणाली को डिजाइन करने के लिए जिम्मेदार व्यक्ति को कहा जाता हैsystem analyst

आवश्यक भीड़ जुटना

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

  • क्या हो रहा है?
  • यह कैसे किया जा रहा है?
  • किसी कार्य की आवृत्ति क्या है?
  • निर्णय या लेन-देन की मात्रा क्या है?
  • किन समस्याओं का सामना करना पड़ रहा है?

कुछ तकनीकें जो इस जानकारी को इकट्ठा करने में मदद करती हैं -

  • Interviews
  • Questionnaires
  • मौजूदा सिस्टम दस्तावेजों का अध्ययन
  • व्यापार डेटा का विश्लेषण

सिस्टम विश्लेषकों को SMART की पहचान करने के लिए स्पष्ट और संक्षिप्त लेकिन पूरी तरह से आवश्यक दस्तावेज़ बनाने की आवश्यकता है - विशिष्ट, औसत दर्जे का, सहमत, यथार्थवादी और समय-आधारित - आवश्यकताएं। ऐसा करने में विफलता -

  • अपूर्ण समस्या की परिभाषा
  • गलत कार्यक्रम लक्ष्य
  • ग्राहक के लिए आवश्यक परिणाम देने के लिए फिर से काम करें
  • बढ़ी हुई लागत
  • विलम्बित डिलिवरी

आवश्यक जानकारी की गहराई के कारण, आवश्यकता को इकट्ठा करने के रूप में भी जाना जाता है detailed investigation

समस्या की परिभाषा

आवश्यकताओं को इकट्ठा करने और उनका विश्लेषण करने के बाद, समस्या बयान को स्पष्ट रूप से कहा जाना चाहिए। समस्या की परिभाषा को स्पष्ट रूप से बताना चाहिए कि किस समस्या या समस्या को हल करने की आवश्यकता है। एक स्पष्ट समस्या बयान के लिए आवश्यक है -

  • प्रोजेक्ट स्कोप को परिभाषित करें
  • टीम पर ध्यान केंद्रित रखें
  • प्रोजेक्ट को ट्रैक पर रखें
  • मान्य करें कि वांछित परिणाम परियोजना के अंत में प्राप्त किया गया था

अक्सर, कोडिंग को किसी भी सॉफ्टवेयर विकास प्रक्रिया का सबसे आवश्यक हिस्सा माना जाता है। हालाँकि, कोडिंग प्रक्रिया का एक हिस्सा है और यदि सिस्टम सही ढंग से डिज़ाइन किया गया है तो वास्तव में न्यूनतम समय लग सकता है। सिस्टम को डिज़ाइन करने से पहले, हाथ में समस्या के लिए एक समाधान की पहचान की जानी चाहिए।

सिस्टम को डिजाइन करने के बारे में पहली बात यह ध्यान देने वाली है कि शुरू में सिस्टम विश्लेषक एक से अधिक समाधानों के साथ आ सकते हैं। लेकिन अंतिम समाधान या उत्पाद केवल एक ही हो सकता है। आवश्यकता एकत्रित चरण के दौरान एकत्र किए गए डेटा का गहराई से विश्लेषण एक अद्वितीय समाधान में आने में मदद कर सकता है। समस्या को सही ढंग से परिभाषित करना समाधान के लिए भी महत्वपूर्ण है।

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

flowcharting

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

ये हैं फ्लोचार्टिंग के फायदे -

  • दृश्य प्रतिनिधित्व कार्यक्रम तर्क को समझने में मदद करता है

  • वे वास्तविक कार्यक्रम कोडिंग के लिए ब्लूप्रिंट के रूप में कार्य करते हैं

  • फ्लोचार्ट कार्यक्रम प्रलेखन के लिए महत्वपूर्ण हैं

  • कार्यक्रम रखरखाव के दौरान फ्लोचार्ट एक महत्वपूर्ण सहायता है

ये हैं फ्लोचार्टिंग के नुकसान -

  • फ्लोचार्ट का उपयोग करके जटिल तर्क को चित्रित नहीं किया जा सकता है

  • तर्क या डेटा / कार्य प्रवाह में किसी भी परिवर्तन के मामले में, फ्लोचार्ट को पूरी तरह से फिर से तैयार करना होगा

आंकड़ा प्रवाह आरेख

डेटा प्रवाह आरेख या DFD एक प्रणाली या उप-प्रणाली के माध्यम से डेटा प्रवाह का एक चित्रमय प्रतिनिधित्व है। प्रत्येक प्रक्रिया का अपना डेटा प्रवाह होता है और डेटा प्रवाह आरेख के स्तर होते हैं। स्तर 0 पूरे सिस्टम के लिए इनपुट और आउटपुट डेटा दिखाता है। तब सिस्टम मॉड्यूल में टूट जाता है और स्तर 1 डीएफडी प्रत्येक मॉड्यूल के लिए अलग से डेटा प्रवाह दिखाता है। यदि आवश्यक हो और 2 DFD स्तर पर मॉड्यूल को उप-मॉड्यूल में तोड़ा जा सकता है।

स्यूडोकोड

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

यहाँ C ++ में स्यूडोकोड का एक उदाहरण दिया गया है। प्रोग्रामर को प्रोग्राम कोड प्राप्त करने के लिए बस प्रत्येक कथन को C ++ सिंटैक्स में अनुवाद करना होगा।

गणितीय संक्रियाओं की पहचान करना

कंप्यूटर के सभी निर्देश अंततः मशीन स्तर पर अंकगणितीय और तार्किक संचालन के रूप में कार्यान्वित किए जाते हैं। ये ऑपरेशन महत्वपूर्ण हैं क्योंकि वे -

  • स्मृति स्थान पर कब्जा
  • निष्पादन में समय लें
  • सॉफ्टवेयर दक्षता निर्धारित करें
  • समग्र सॉफ्टवेयर प्रदर्शन को प्रभावित करता है

सिस्टम विश्लेषक हाथ में समस्या के अनूठे समाधान की पहचान करते हुए सभी प्रमुख गणितीय कार्यों की पहचान करने का प्रयास करते हैं।

एक वास्तविक जीवन की समस्या जटिल और बड़ी है। यदि एक अखंड समाधान विकसित किया जाता है तो यह इन समस्याओं का कारण बनता है -

  • एक बड़े कार्यक्रम को लिखना, परीक्षण और कार्यान्वित करना मुश्किल है

  • अंतिम उत्पाद वितरित होने के बाद संशोधन असंभव के करीब है

  • कार्यक्रम का रखरखाव बहुत मुश्किल है

  • एक त्रुटि पूरे सिस्टम को रोक सकती है

इन समस्याओं को दूर करने के लिए, समाधान को छोटे भागों में विभाजित किया जाना चाहिए modules। विकास, कार्यान्वयन, संशोधन और रखरखाव में आसानी के लिए छोटे मॉड्यूल में एक बड़े समाधान को तोड़ने की तकनीक को कहा जाता हैmodular technique प्रोग्रामिंग या सॉफ्टवेयर विकास के।

मॉड्यूलर प्रोग्रामिंग के लाभ

मॉड्यूलर प्रोग्रामिंग में ये फायदे हैं -

  • तेजी से विकास को सक्षम करता है क्योंकि प्रत्येक मॉड्यूल को समानांतर में विकसित किया जा सकता है

  • मॉड्यूल फिर से इस्तेमाल किया जा सकता है

  • जैसा कि प्रत्येक मॉड्यूल को स्वतंत्र रूप से जांचना है, परीक्षण तेज और अधिक मजबूत है

  • डिबगिंग और पूरे कार्यक्रम का रखरखाव आसान

  • मॉड्यूल छोटे होते हैं और उनमें जटिलता का स्तर कम होता है इसलिए उन्हें समझना आसान होता है

मॉड्यूल की पहचान करना

किसी सॉफ्टवेयर में मॉड्यूल की पहचान करना एक दिमाग का काम है क्योंकि ऐसा करने का एक सही तरीका नहीं हो सकता है। मॉड्यूल की पहचान करने के लिए यहां कुछ संकेत दिए गए हैं -

  • यदि डेटा सिस्टम का सबसे महत्वपूर्ण तत्व है, तो संबंधित डेटा को संभालने वाले मॉड्यूल बनाएं।

  • यदि सिस्टम द्वारा प्रदान की गई सेवा विविध है, तो सिस्टम को कार्यात्मक मॉड्यूल में तोड़ दें।

  • यदि अन्य सभी विफल हो जाते हैं, तो आवश्यकता को इकट्ठा करने के चरण के दौरान सिस्टम की अपनी समझ के अनुसार सिस्टम को तार्किक मॉड्यूल में तोड़ दें।

कोडिंग के लिए, प्रत्येक मॉड्यूल को प्रोग्रामिंग की आसानी के लिए फिर से छोटे मॉड्यूल में तोड़ना पड़ता है। यह फिर से ऊपर साझा किए गए तीन सुझावों का उपयोग करके किया जा सकता है, विशिष्ट प्रोग्रामिंग नियमों के साथ संयुक्त। उदाहरण के लिए, C ++ और Java जैसी ऑब्जेक्ट ओरिएंटेड प्रोग्रामिंग लैंग्वेज के लिए, प्रत्येक वर्ग अपने डेटा और विधियों के साथ एकल मॉड्यूल बना सकता है।

चरण-दर-चरण समाधान

मॉड्यूल को लागू करने के लिए, प्रत्येक मॉड्यूल की प्रक्रिया प्रवाह को चरणबद्ध तरीके से वर्णित किया जाना चाहिए। स्टेप बाई स्टेप सॉल्यूशन का उपयोग करके विकसित किया जा सकता हैalgorithms या pseudocodes। स्टेप बाय स्टेप सॉल्यूशन देने से ये फायदे मिलते हैं -

  • समाधान पढ़ने वाला कोई भी व्यक्ति समस्या और समाधान दोनों को समझ सकता है।

  • यह प्रोग्रामर और गैर-प्रोग्रामर द्वारा समान रूप से समझा जा सकता है।

  • कोडिंग के दौरान प्रत्येक स्टेटमेंट को प्रोग्राम स्टेटमेंट में बदलना होता है।

  • यह प्रलेखन का हिस्सा हो सकता है और कार्यक्रम के रखरखाव में सहायता कर सकता है।

  • पहचानकर्ता नाम, आवश्यक संचालन आदि जैसे सूक्ष्म-स्तरीय विवरण स्वचालित रूप से काम करते हैं

आइए एक उदाहरण देखें।

नियंत्रण संरचनाएं

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

एल्गोरिदम और pseudocodes नियंत्रण संरचनाओं की आवश्यकता है, जहां की पहचान करने में विश्लेषकों और प्रोग्रामर की मदद करें।

नियंत्रण संरचनाएं इन तीन प्रकारों की होती हैं -

निर्णय नियंत्रण संरचनाएं

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

चयन नियंत्रण संरचनाएं

चयन नियंत्रण संरचनाओं का उपयोग तब किया जाता है जब कार्यक्रम अनुक्रम किसी विशिष्ट प्रश्न के उत्तर पर निर्भर करता है। उदाहरण के लिए, एक प्रोग्राम में उपयोगकर्ता के लिए कई विकल्प होते हैं। अगला निष्पादित किया जाने वाला बयान चुने गए विकल्प पर निर्भर करेगा। उदाहरण के लिए,switch बयान, case बयान।

दोहराव / पाश नियंत्रण संरचनाएं

दोहराव नियंत्रण संरचना का उपयोग तब किया जाता है जब कई बार बयानों का एक सेट दोहराया जाता है। पुनरावृत्ति की संख्या शुरू होने से पहले ज्ञात हो सकती है या किसी अभिव्यक्ति के मूल्य पर निर्भर हो सकती है। उदाहरण के लिए,for बयान, while बयान, do while बयान, आदि

जैसा कि आप ऊपर की छवि में देख सकते हैं, चयन और निर्णय संरचना दोनों एक फ्लोचार्ट में समान रूप से कार्यान्वित किए जाते हैं। चयन नियंत्रण कुछ और नहीं बल्कि क्रमबद्ध रूप से लिए गए निर्णय कथनों की एक श्रृंखला है।

ये कथन कैसे काम करते हैं, यह दिखाने के लिए कार्यक्रमों के कुछ उदाहरण यहां दिए गए हैं -

किसी भी समस्या को हल करने के लिए जिन चरणों का पालन करना आवश्यक है, उन्हें कहा जाता है algorithm। एल्गोरिथ्म आमतौर पर वास्तविक कोडिंग से पहले विकसित किया जाता है। यह अंग्रेजी की तरह भाषा का उपयोग करते हुए लिखा गया है ताकि यह गैर-प्रोग्रामर द्वारा भी आसानी से समझा जा सके।

कभी-कभी एल्गोरिदम का उपयोग करके लिखा जाता है pseudocodes, यानी उपयोग की जाने वाली प्रोग्रामिंग भाषा के समान भाषा। किसी समस्या को हल करने के लिए एल्गोरिथ्म लिखना ये फायदे प्रदान करता है -

  • टीम के सदस्यों के बीच प्रभावी संचार को बढ़ावा देता है

  • हाथ में समस्या का विश्लेषण करने में सक्षम बनाता है

  • कोडिंग के लिए ब्लूप्रिंट के रूप में कार्य करता है

  • डिबगिंग में सहायता करता है

  • रखरखाव के चरण के दौरान भविष्य के संदर्भ के लिए सॉफ्टवेयर प्रलेखन का हिस्सा बन जाता है

ये एक अच्छे और सही एल्गोरिदम की विशेषताएं हैं -

  • इनपुट्स का एक सेट है

  • कदम विशिष्ट रूप से परिभाषित हैं

  • चरणों की परिमित संख्या है

  • वांछित उत्पादन करता है

उदाहरण एल्गोरिदम

आइए हम पहले एल्गोरिथ्म बनाने के लिए वास्तविक जीवन की स्थिति का एक उदाहरण लेते हैं। यहाँ कलम खरीदने के लिए बाजार में जाने के लिए एल्गोरिथ्म है।

इस एल्गोरिथम में चरण 4 अपने आप में एक पूर्ण कार्य है और इसके लिए अलग एल्गोरिथ्म लिखा जा सकता है। आइए अब यह जांचने के लिए एक एल्गोरिथ्म बनाएं कि नंबर पॉजिटिव है या नेगेटिव।

Flowchartएक कार्यक्रम के तार्किक चरणों के अनुक्रम का एक आरेखीय प्रतिनिधित्व है। फ़्लोचार्ट संबंधों और प्रक्रिया / डेटा प्रवाह को दिखाने के लिए प्रक्रियाओं और तीरों को चित्रित करने के लिए सरल ज्यामितीय आकृतियों का उपयोग करते हैं।

फ्लोचार्ट प्रतीक

यहाँ कुछ सामान्य प्रतीकों के लिए एक चार्ट दिया गया है जो फ्लोचार्टों को खींचने में उपयोग किया जाता है।

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

फ्लोचार्ट विकसित करने के लिए दिशानिर्देश

फ्लोचार्ट विकसित करते समय ध्यान रखने योग्य ये कुछ बिंदु हैं -

  • फ़्लोचार्ट में केवल एक शुरुआत और एक स्टॉप प्रतीक हो सकता है

  • ऑन-पेज कनेक्टर को संख्याओं का उपयोग करके संदर्भित किया जाता है

  • ऑफ-पेज कनेक्टर को अल्फाबेट्स का उपयोग करके संदर्भित किया जाता है

  • प्रक्रियाओं का सामान्य प्रवाह ऊपर से नीचे या दाएं से बाएं होता है

  • तीर एक दूसरे को पार नहीं करना चाहिए

उदाहरण फ़्लोचार्ट्स

यहाँ कलम खरीदने के लिए बाज़ार जाने के लिए फ़्लोचार्ट है।

यहां दो संख्याओं के औसत की गणना के लिए एक फ्लोचार्ट दिया गया है।

जैसा कि आप जानते हैं, कंप्यूटर की खुद की बुद्धि नहीं है; यह केवल इस प्रकार हैinstructions उपयोगकर्ता द्वारा दिया गया। Instructionsएक कंप्यूटर प्रोग्राम के बिल्डिंग ब्लॉक्स हैं, और इसलिए एक सॉफ्टवेयर है। एक सफल कार्यक्रम बनाने के लिए स्पष्ट निर्देश देना महत्वपूर्ण है। एक प्रोग्रामर या सॉफ्टवेयर डेवलपर के रूप में, आपको स्पष्ट निर्देश लिखने की आदत डालनी चाहिए। यहाँ ऐसा करने के दो तरीके हैं।

भावों की स्पष्टता

एक कार्यक्रम में अभिव्यक्ति एक अंकगणितीय या तार्किक गणना करने के लिए ऑपरेटरों और ऑपरेटरों का एक क्रम है। यहाँ कुछ मान्यताओं के उदाहरण दिए गए हैं -

  • दो मूल्यों की तुलना
  • एक चर, वस्तु या वर्ग को परिभाषित करना
  • एक या अधिक चर का उपयोग करके अंकगणितीय गणना
  • डेटाबेस से डेटा पुनर्प्राप्त करना
  • डेटाबेस में मूल्यों को अद्यतन करना

असंदिग्ध अभिव्यक्ति लिखना एक ऐसा कौशल है जिसे हर प्रोग्रामर को विकसित करना चाहिए। इस तरह के भाव लिखते समय कुछ बिंदुओं को ध्यान में रखा जाना चाहिए -

असंदिग्ध परिणाम

अभिव्यक्ति का मूल्यांकन एक स्पष्ट कट परिणाम देना चाहिए। उदाहरण के लिए, एक्री संचालकों का उपयोग सावधानी के साथ किया जाना चाहिए।

जटिल भावों से बचें

एक ही अभिव्यक्ति में कई चीजें हासिल करने की कोशिश न करें। दो या दो से अधिक अभिव्यक्तियों में पल टूटना चीजें जटिल होने लगती हैं।

निर्देशों की सादगी

यह केवल उन कंप्यूटरों के लिए नहीं है जिन्हें आपको स्पष्ट निर्देश लिखने की आवश्यकता है। कार्यक्रम को पढ़ने वाला कोई भी (बाद में आप भी !!) यह समझने में सक्षम होना चाहिए कि निर्देश क्या हासिल करने की कोशिश कर रहा है। कुछ समय बीत जाने के बाद जब प्रोग्रामर इसे रिवाइज करते हैं, तो प्रोग्रामर्स का खुद का हैंग न होना बहुत आम बात है। यह इंगित करता है कि ऐसे कार्यक्रमों का रखरखाव और संशोधन काफी कठिन होगा।

सरल निर्देश लिखने से इस समस्या से बचने में मदद मिलती है। यहाँ सरल निर्देश लिखने के लिए कुछ सुझाव दिए गए हैं -

  • Avoid clever instructions - चतुर निर्देश शायद उस चतुर को बाद में न देखें यदि कोई इसे ठीक से समझ नहीं पा रहा है।

  • One instruction per task - एक समय में एक से अधिक काम करने की कोशिश करना निर्देशों को जटिल करता है।

  • Use standards- हर भाषा के अपने मानक होते हैं, उनका पालन करें। याद रखें कि आप परियोजना पर अकेले काम नहीं कर रहे हैं; कोडिंग के लिए प्रोजेक्ट मानकों और दिशानिर्देशों का पालन करें।

इस अध्याय में, हम कवर करेंगे कि एक अच्छा कार्यक्रम कैसे लिखें। लेकिन ऐसा करने से पहले, आइए देखें कि एक अच्छे कार्यक्रम की विशेषताएं क्या हैं -

  • Portable- प्रोग्राम या सॉफ्टवेयर एक ही प्रकार के सभी कंप्यूटरों पर चलना चाहिए। उसी प्रकार से हमारा मतलब है कि पर्सनल कंप्यूटर के लिए विकसित एक सॉफ्टवेयर सभी पीसी पर चलना चाहिए। या गोलियों के लिए लिखे गए एक सॉफ्टवेयर को सही विनिर्देशों वाले सभी टैबलेटों पर चलना चाहिए।

  • Efficient- एक सॉफ्टवेयर जो असाइन किए गए कार्यों को जल्दी करता है, कुशल कहा जाता है। कोड अनुकूलन और मेमोरी ऑप्टिमाइज़ेशन प्रोग्राम दक्षता बढ़ाने के कुछ तरीके हैं।

  • Effective- सॉफ्टवेयर को हाथ में समस्या को हल करने में सहायता करनी चाहिए। एक सॉफ्टवेयर जो ऐसा करता है उसे प्रभावी कहा जाता है।

  • Reliable - प्रोग्राम को एक ही आउटपुट हर बार इनपुट के समान सेट को देना चाहिए।

  • User friendly - प्रोग्राम इंटरफ़ेस, क्लिक करने योग्य लिंक और आइकन, आदि उपयोगकर्ता के अनुकूल होने चाहिए।

  • Self-documenting - कोई भी प्रोग्राम या सॉफ्टवेयर जिसका पहचानकर्ता नाम, मॉड्यूल नाम आदि स्पष्ट नामों के उपयोग के कारण खुद का वर्णन कर सकता है।

यहां कुछ तरीके दिए गए हैं जिनसे अच्छे कार्यक्रम लिखे जा सकते हैं।

उचित पहचानकर्ता नाम

किसी चर, वस्तु, फलन, वर्ग या विधि की पहचान करने वाला नाम a कहलाता है identifier। उचित पहचानकर्ता नाम देने से एक कार्यक्रम स्व-दस्तावेजीकरण बन जाता है। इसका मतलब यह है कि ऑब्जेक्ट का नाम बताएगा कि यह क्या करता है या यह क्या जानकारी संग्रहीत करता है। आइए इस SQL ​​निर्देश का एक उदाहरण लेते हैं:

लाइन 10 देखें। यह प्रोग्राम पढ़ने वाले किसी को भी बताता है कि एक छात्र की आईडी, नाम और रोल नंबर का चयन किया जाना है। चरों के नाम इसे आत्म-व्याख्यात्मक बनाते हैं। ये उचित पहचानकर्ता नाम बनाने के लिए कुछ सुझाव हैं -

  • भाषा दिशानिर्देशों का उपयोग करें

  • स्पष्टता बनाए रखने के लिए लंबे नाम देने से शर्माएं नहीं

  • अपरकेस और लोअरकेस अक्षरों का उपयोग करें

  • दो पहचानकर्ताओं को एक ही नाम न दें, भले ही भाषा इसकी अनुमति दे

  • एक से अधिक पहचानकर्ता को एक ही नाम न दें, भले ही उनके परस्पर अनन्य दायरे हों

टिप्पणियाँ

ऊपर की छवि में, लाइन 8 देखें। यह पाठक को बताता है कि कोड की अगली कुछ पंक्तियाँ उन छात्रों की सूची को पुनः प्राप्त करेगी जिनके रिपोर्ट कार्ड को जनरेट किया जाना है। यह लाइन कोड का हिस्सा नहीं है, लेकिन केवल प्रोग्राम को अधिक उपयोगकर्ता के अनुकूल बनाने के लिए दिया गया है।

ऐसी अभिव्यक्ति जिसे संकलित नहीं किया जाता है लेकिन प्रोग्रामर के लिए एक नोट या स्पष्टीकरण के रूप में लिखा जाता है comment। निम्नलिखित कार्यक्रम खंड में टिप्पणियों को देखें। टिप्पणियाँ // से शुरू होती हैं।

टिप्पणियाँ के रूप में डाला जा सकता है -

  • कार्यक्रम में अपने उद्देश्य की व्याख्या करने के लिए प्रस्ताव

  • तार्किक या कार्यात्मक ब्लॉकों की शुरुआत और / या अंत में

  • विशेष परिदृश्य या अपवादों के बारे में ध्यान दें

आपको पढ़ने के दौरान कोड के प्रवाह को तोड़कर उल्टा साबित करने वाले भद्दे कमेंट जोड़ने से बचना चाहिए। कंपाइलर टिप्पणियों और इंडेंटेशन को नजरअंदाज कर सकता है लेकिन पाठक उनमें से हर एक को पढ़ता है।

खरोज

बाएं या दाएं मार्जिन से पाठ की दूरी को कहा जाता है indent। कार्यक्रमों में, इंडेंटेशन का उपयोग कोड के तार्किक रूप से अलग ब्लॉकों को अलग करने के लिए किया जाता है। यहाँ प्रस्तुत कार्यक्रम खंड का एक उदाहरण है:

जैसा कि आप देख सकते हैं, इंडेंटेड प्रोग्राम अधिक समझने योग्य है। से नियंत्रण का प्रवाहfor loop सेवा if और वापस forबहुत स्पष्ट है। नियंत्रण संरचनाओं के मामले में इंडेंटेशन विशेष रूप से उपयोगी है।

रिक्त स्थानों या लाइनों को सम्मिलित करना भी इंडेंटेशन का हिस्सा है। यहां कुछ स्थितियां हैं जहां आप कर सकते हैं और इंडेंटेशन का उपयोग करना चाहिए -

  • Blank lines between logical or functional blocks of code within the program

  • Blank spaces around operators

  • Tabs at the beginning of new control structures

Identifying and removing errors from a program or software is called debugging. Debugging is ideally part of testing process but in reality it is done at every step of programming. Coders should debug the smallest of their modules before moving on. This decreases the number of errors thrown up during the testing phase and reduces testing time and effort significantly. Let us look at the types of errors that can crop up in a program.

Syntax Errors

Syntax errors are the grammatical errors in a program. Every language has its own set of rules, like creating identifiers, writing expressions, etc. for writing programs. When these rules are violated, the errors are called syntax errors. Many modern integrated development environments can identify the syntax errors as you type your program. Else, it will be shown when you compile the program. Let us take an example −

In this program, the variable prod has not been declared, which is thrown up by the compiler.

Semantic Errors

Semantic errors are also called logical errors. The statement has no syntax errors, so it will compile and run correctly. However, it will not give the desired output as the logic is not correct. Let us take an example.

Look at line 13. Here programmer wants to check if the divisor is 0, to avoid division by 0. However, instead of using the comparing operator ==, assignment operator = has been used. Now every time the “if expression” will evaluate to true and program will give output as “You cannot divide by 0”. Definitely not what was intended!!

Logical errors cannot be detected by any program; they have to be identified by the programmer herself when the desired output is not achieved.

Runtime Errors

Runtime errors are errors that occur while executing the program. This implies that the program has no syntax errors. Some of the most common run time errors your program may encounter are −

  • Infinite loop
  • Division by '0'
  • Wrong value entered by user (say, string instead of integer)

Code Optimization

Any method by which code is modified to improve its quality and efficiency is called code optimization. Code quality determines life span of code. If the code can be used and maintained for a long period of time, carried over from product to product, its quality is deemed to be high and it has a longer life. On the contrary, if a piece of code can be used and maintained only for short durations, say till a version is valid, it is deemed to be of low quality and has a short life.

Reliability and speed of a code determines code efficiency. Code efficiency is an important factor in ensuring high performance of a software.

There are two approaches to code optimization −

  • Intuition based optimization (IBO) − Here the programmer tries to optimize the program based on her own skill and experience. This might work for small programs but fails miserably as complexity of the program grows.

  • Evidence based optimization (EBO) − Here automated tools are used to find out performance bottlenecks and then relevant portions optimize accordingly. Every programming language has its own set of code optimization tools. For example, PMD, FindBug and Clover are used to optimize Java code.

Code is optimized for execution time and memory consumption because time is scarce and memory expensive. There has to be a balance between the two. If time optimization increases load on memory or memory optimization makes the code slower, purpose of optimization will be lost.

Execution Time Optimization

Optimizing code for execution time is necessary to provide fast service to the users. Here are some tips for execution time optimization −

  • Use commands that have built-in execution time optimization

  • Use switch instead of if condition

  • Minimize function calls within loop structures

  • Optimize the data structures used in the program

Memory Optimization

As you know, data and instructions consume memory. When we say data, it also refers to interim data that is the result of expressions. We also need to keep a track of how many instructions are making up the program or the module we are trying to optimize. Here are some tips for memory optimization

  • Use commands that have built-in memory optimization

  • Keep the use of variables that need to be stored in registers minimum

  • Avoid declaring global variables inside loops that are executed many times

  • Avoid using CPU intensive functions like sqrt()

Any written text, illustrations or video that describe a software or program to its users is called program or software document. User can be anyone from a programmer, system analyst and administrator to end user. At various stages of development multiple documents may be created for different users. In fact, software documentation is a critical process in the overall software development process.

In modular programming documentation becomes even more important because different modules of the software are developed by different teams. If anyone other than the development team wants to or needs to understand a module, good and detailed documentation will make the task easier.

These are some guidelines for creating the documents −

  • Documentation should be from the point of view of the reader

  • Document should be unambiguous

  • There should be no repetition

  • Industry standards should be used

  • Documents should always be updated

  • Any outdated document should be phased out after due recording of the phase out

Advantages of Documentation

These are some of the advantages of providing program documentation −

  • Keeps track of all parts of a software or program

  • Maintenance is easier

  • Programmers other than the developer can understand all aspects of software

  • Improves overall quality of the software

  • Assists in user training

  • Ensures knowledge de-centralization, cutting costs and effort if people leave the system abruptly

Example Documents

A software can have many types of documents associated with it. Some of the important ones include −

  • User manual − It describes instructions and procedures for end users to use the different features of the software.

  • Operational manual − It lists and describes all the operations being carried out and their inter-dependencies.

  • Design Document − It gives an overview of the software and describes design elements in detail. It documents details like data flow diagrams, entity relationship diagrams, etc.

  • Requirements Document − It has a list of all the requirements of the system as well as an analysis of viability of the requirements. It can have user cases, reallife scenarios, etc.

  • Technical Documentation − It is a documentation of actual programming components like algorithms, flowcharts, program codes, functional modules, etc.

  • Testing Document − It records test plan, test cases, validation plan, verification plan, test results, etc. Testing is one phase of software development that needs intensive documentation.

  • List of Known Bugs − Every software has bugs or errors that cannot be removed because either they were discovered very late or are harmless or will take more effort and time than necessary to rectify. These bugs are listed with program documentation so that they may be removed at a later date. Also they help the users, implementers and maintenance people if the bug is activated.

Program maintenance is the process of modifying a software or program after delivery to achieve any of these outcomes −

  • Correct errors
  • Improve performance
  • Add functionalities
  • Remove obsolete portions

Despite the common perception that maintenance is required to fix errors that come up after the software goes live, in reality most of the maintenance work involves adding minor or major capabilities to existing modules. For example, some new data is added to a report, a new field added to entry forms, code to be modified to incorporate changed government laws, etc.

Types of Maintenance

Maintenance activities can be categorized under four headings −

  • Corrective maintenance − Here errors that come up after on-site implementation are fixed. The errors may be pointed out by the users themselves.

  • Preventive maintenance − Modifications done to avoid errors in future are called preventive maintenance.

  • Adaptive maintenance − Changes in the working environment sometimes require modifications in the software. This is called adaptive maintenance. For example, if government education policy changes, corresponding changes have to be made in student result processing module of school management software.

  • Perfective maintenance − Changes done in the existing software to incorporate new requirements from the client is called perfective maintenance. Aim here is to be always be up-to-date with the latest technology.

Maintenance Tools

Software developers and programmers use many tools to assist them in software maintenance. Here are some of the most widely used −

  • Program slicer − selects a part of the program that would be affected by the change

  • Data flow analyzer − tracks all possible flows of data in the software

  • Dynamic analyzer − traces program execution path

  • Static analyzer − allows general viewing and summarizing of the program

  • Dependency analyzer − assists in understanding and analyzing interdependence of different parts of the program