सॉफ्टवेयर इंजीनियरिंग साक्षात्कार प्रश्न
प्रिय पाठकों, ये Software Engineering Interview Questions विशेष रूप से आपको उन प्रश्नों की प्रकृति से परिचित कराने के लिए डिज़ाइन किया गया है जिनके विषय के लिए आपके साक्षात्कार के दौरान सामना हो सकता है Software Engineering। मेरे अनुभव के अनुसार, अच्छे साक्षात्कारकर्ताओं ने शायद ही आपके साक्षात्कार के दौरान किसी विशेष प्रश्न को पूछने की योजना बनाई हो, आम तौर पर प्रश्न विषय की कुछ मूल अवधारणा से शुरू होते हैं और बाद में वे आगे की चर्चा और आपके द्वारा दिए गए उत्तर के आधार पर जारी रहते हैं:
Q.What is computer software?
A. कंप्यूटर सॉफ्टवेयर एक पूर्ण पैकेज है, जिसमें सॉफ्टवेयर प्रोग्राम, इसके प्रलेखन और सॉफ्टवेयर का उपयोग करने के लिए उपयोगकर्ता गाइड शामिल हैं।
Q.Can you differentiate computer software and computer program?
A. एक कंप्यूटर प्रोग्राम प्रोग्रामिंग कोड का एक टुकड़ा है जो एक अच्छी तरह से परिभाषित कार्य करता है जहां सॉफ्टवेयर में प्रोग्रामिंग कोड, इसके प्रलेखन और उपयोगकर्ता गाइड शामिल हैं।
Q.What is software engineering?
A. सॉफ्टवेयर इंजीनियरिंग सॉफ्टवेयर सिस्टम डेवलपमेंट से जुड़ी एक इंजीनियरिंग शाखा है।
Q.When you know programming, what is the need to learn software engineering concepts?
A.एक व्यक्ति जो जानता है कि एक दीवार का निर्माण कैसे किया जा सकता है एक पूरे घर के निर्माण में अच्छा नहीं है। इसी तरह, प्रोग्राम लिखने वाले व्यक्ति को सॉफ्टवेयर इंजीनियरिंग की अन्य अवधारणाओं का ज्ञान नहीं हो सकता है। सॉफ्टवेयर इंजीनियरिंग अवधारणाएँ प्रोग्रामर को गाइड करती हैं कि अंत उपयोगकर्ता की आवश्यकताओं का आकलन कैसे करें, वास्तविक कोडिंग शुरू होने से पहले एल्गोरिदम डिज़ाइन करें, कोडिंग और कोड का परीक्षण करके प्रोग्राम बनाएँ।
Q.What is software process or Software Development Life Cycle (SDLC)?
A.सॉफ्टवेयर डेवलपमेंट लाइफ साइकल, या सॉफ्टवेयर प्रक्रिया, विकास क्रम में हर चरण का पालन करके सॉफ्टवेयर की व्यवस्थित विकास है, उस क्रम में रिक्वायरमेंट गैदरिंग, सिस्टम एनालिसिस, डिज़ाइन, कोडिंग, टेस्टिंग, मेंटेनेंस और डॉक्यूमेंटेशन।
Q.What are SDLC models available?
A. कई एसडीएलसी मॉडल उपलब्ध हैं जैसे वाटरफॉल मॉडल, इटरेटिव मॉडल, सर्पिल मॉडल, वी-मॉडल और बिग-बैंग मॉडल आदि।
Q.What are various phases of SDLC?
A.एसडीएलसी के सामान्य चरण हैं: आवश्यकता एकत्रीकरण, सिस्टम विश्लेषण और डिजाइन, कोडिंग, परीक्षण और कार्यान्वयन। चरण उस मॉडल पर निर्भर करते हैं जो हम सॉफ़्टवेयर विकसित करने के लिए चुनते हैं।
Q.Which SDLC model is the best?
A.एसडीएलसी मॉडल को विकास प्रक्रिया की आवश्यकताओं के अनुसार अपनाया जाता है। यह सुनिश्चित करने के लिए बहुत सॉफ्टवेयर-से-सॉफ्टवेयर हो सकता है कि कौन सा मॉडल उपयुक्त है।
यदि उत्तर संतुष्ट हैं तो हम सबसे अच्छा एसडीएलसी मॉडल चुन सकते हैं -
- सॉफ्टवेयर को लागू करने के लिए एसडीएलसी चयनित तकनीक के लिए उपयुक्त है?
- क्या SDLC ग्राहक की आवश्यकताओं और प्राथमिकताओं के लिए उपयुक्त है?
- क्या SDLC मॉडल सॉफ्टवेयर के आकार और जटिलता के लिए उपयुक्त है?
- क्या एसडीएलसी मॉडल उन प्रकार की परियोजनाओं और इंजीनियरिंग के लिए उपयुक्त है जो हम करते हैं?
- एसडीएलसी भौगोलिक रूप से सह-स्थित या बिखरे डेवलपर्स के लिए उपयुक्त है?
Q.What is software project management?
A. सॉफ्टवेयर परियोजना प्रबंधन सॉफ्टवेयर विकास में शामिल समय, लागत और गुणवत्ता प्रबंधन जैसी सभी गतिविधियों के प्रबंधन की प्रक्रिया है।
Q.Who is software project manager?
A. एक सॉफ्टवेयर प्रोजेक्ट मैनेजर वह व्यक्ति होता है जो सॉफ्टवेयर प्रोजेक्ट को पूरा करने की जिम्मेदारी लेता है।
Q.What does software project manager do?
A. सॉफ्टवेयर परियोजना प्रबंधक सॉफ्टवेयर प्रबंधन गतिविधियों के साथ जुड़ा हुआ है। वह परियोजना नियोजन, प्रगति की निगरानी, हितधारकों के बीच संचार, जोखिम और संसाधनों के प्रबंधन, विकास के सुचारू निष्पादन और समय, लागत और गुणवत्ता के संदर्भ में परियोजना को वितरित करने के लिए जिम्मेदार है।
Q.What is software scope?
A. सॉफ्टवेयर गुंजाइश एक अच्छी तरह से परिभाषित सीमा है, जो सॉफ्टवेयर उत्पाद को विकसित करने और वितरित करने के लिए की जाने वाली सभी गतिविधियों को शामिल करती है।
सॉफ्टवेयर का दायरा स्पष्ट रूप से सभी कार्यात्मकताओं और कलाकृतियों को परिभाषित करता है, जिन्हें सॉफ्टवेयर के एक भाग के रूप में वितरित किया जाता है। गुंजाइश की पहचान करता है कि उत्पाद क्या करेगा और यह क्या नहीं करेगा, अंत उत्पाद में क्या होगा और इसमें क्या नहीं होगा।
Q.What is project estimation?
A.यह प्रयासों, समय और संसाधनों के संदर्भ में विकास की लागत की गणना करने के लिए सॉफ्टवेयर उत्पाद के विभिन्न पहलुओं का अनुमान लगाने की एक प्रक्रिया है। यह अनुमान पिछले अनुभव से, विशेषज्ञों से परामर्श करके या पूर्व-निर्धारित सूत्रों का उपयोग करके प्राप्त किया जा सकता है।
Q.How can we derive the size of software product?
A. सॉफ्टवेयर उत्पाद का आकार दो तरीकों में से किसी एक का उपयोग करके गणना की जा सकती है -
- वितरित कोड की पंक्तियों की गिनती
- दिए गए फंक्शन पॉइंट्स की गिनती
Q.What are function points?
A.समारोह बिंदु सॉफ्टवेयर उत्पाद द्वारा प्रदान की जाने वाली विभिन्न विशेषताएं हैं। इसे सॉफ्टवेयर आकार के लिए माप की इकाई माना जाता है।
Q.What are software project estimation techniques available?
A. कई अनुमान तकनीक उपलब्ध हैं। सबसे अधिक व्यापक रूप से उपयोग किया जाता है -
- अपघटन तकनीक (कोड और फ़ंक्शन बिंदुओं की गिनती लाइनें)
- अनुभवजन्य तकनीक (पुतनाम और सीओकॉमो)।
Q.What is baseline?
A.बेसलाइन एक माप है जो एक चरण की पूर्णता को परिभाषित करता है। एक विशेष चरण से जुड़ी सभी गतिविधियों को पूरा करने के बाद, चरण पूरा हो गया है और अगले चरण के लिए आधार रेखा के रूप में कार्य करता है।
Q.What is Software configuration management?
A. सॉफ़्टवेयर कॉन्फ़िगरेशन प्रबंधन उत्पाद की आवश्यकताओं, डिज़ाइन, कार्यों और विकास के संदर्भ में सॉफ़्टवेयर में परिवर्तनों को ट्रैक करने और नियंत्रित करने की एक प्रक्रिया है।
Q.What is change control?
A. परिवर्तन नियंत्रण कॉन्फ़िगरेशन प्रबंधन का कार्य है, जो यह सुनिश्चित करता है कि सॉफ्टवेयर सिस्टम में किए गए सभी परिवर्तन सुसंगत हैं और संगठनात्मक नियमों और विनियमों के अनुसार किए गए हैं।
Q.How can you measure project execution?
A. हम एक्टिविटी मॉनिटरिंग, स्टेटस रिपोर्ट्स और माइलस्टोन चेकलिस्ट्स के माध्यम से प्रोजेक्ट निष्पादन को माप सकते हैं।
Q.Mention some project management tools.
A.सॉफ्टवेयर परियोजना और संगठन नीतियों की आवश्यकताओं के अनुसार विभिन्न परियोजना प्रबंधन उपकरण उपयोग किए जाते हैं। इनमें गैंट चार्ट, पीईआरटी चार्ट, रिसोर्स हिस्टोग्राम, क्रिटिकल पाथ एनालिसिस, स्टेटस रिपोर्ट्स, माइलस्टोन चेकलिस्ट आदि शामिल हैं।
Q.What are software requirements?
A.सॉफ़्टवेयर आवश्यकताएँ प्रस्तावित सॉफ़्टवेयर सिस्टम का कार्यात्मक विवरण हैं। आवश्यकताओं को लक्ष्य प्रणाली, इसकी कार्यक्षमता और सुविधाओं का विवरण माना जाता है। आवश्यकताएँ सिस्टम से उपयोगकर्ताओं की अपेक्षाओं को व्यक्त करती हैं।
Q.What is feasibility study?
A.यह आकलन करने का एक उपाय है कि एक संगठन के लिए सॉफ्टवेयर परियोजना का विकास कितना व्यावहारिक और लाभदायक होगा। सॉफ्टवेयर विश्लेषक परियोजना की आर्थिक, तकनीकी और परिचालन व्यवहार्यता को समझने के लिए गहन अध्ययन करता है।
Economic - संसाधन परिवहन, प्रशिक्षण के लिए लागत, अतिरिक्त उपयोगिताओं और उपकरणों की लागत और परियोजना की लागत और लाभों का समग्र अनुमान।
Technical - क्या इस प्रणाली को विकसित करना संभव है? मशीन (एस) और ऑपरेटिंग सिस्टम (एस) की उपयुक्तता का आकलन, जिस पर सॉफ्टवेयर निष्पादित करेगा, मौजूदा डेवलपर्स के ज्ञान और कौशल, प्रशिक्षण, उपयोगिताओं या परियोजना के लिए उपकरण।
Operational - क्या संगठन परियोजना की मांग के अनुसार किए गए परिवर्तनों को आसानी से समायोजित कर सकता है? क्या समस्या हल करने लायक है?
Q.How can you gather requirements?
A. आवश्यकताओं को साक्षात्कार, सर्वेक्षण, कार्य विश्लेषण, बुद्धिशीलता, डोमेन विश्लेषण, प्रोटोटाइपिंग, सॉफ्टवेयर के मौजूदा प्रयोग करने योग्य संस्करण का अध्ययन और अवलोकन द्वारा एकत्र किया जा सकता है।
Q.What is SRS?
A.एसआरएस या सॉफ्टवेयर रिक्वायरमेंट स्पेसिफिकेशन आवश्यकता एकत्र करने की प्रक्रिया के समय एक दस्तावेज है। इसे आवश्यकताओं को परिष्कृत करने और उन्हें प्रलेखित करने की प्रक्रिया के रूप में भी देखा जा सकता है।
Q.What are functional requirements?
A. कार्यात्मक आवश्यकताएं प्रस्तावित सॉफ्टवेयर उत्पाद से उपयोगकर्ताओं द्वारा अपेक्षित कार्यात्मक विशेषताएं और विनिर्देश हैं।
Q.What are non-functional requirements?
A. गैर-कार्यात्मक आवश्यकताएं निहित हैं और सुरक्षा, प्रदर्शन, देखने और महसूस करने और उपयोगकर्ता इंटरफ़ेस, अंतर, लागत आदि की सुरक्षा से संबंधित हैं।
Q.What is software measure?
A. सॉफ्टवेयर के मापन को सॉफ्टवेयर की विभिन्न विशेषताओं और पहलुओं की मात्रा और प्रतीक के रूप में समझा जा सकता है।
Q.What is software metric?
A.सॉफ्टवेयर मेट्रिक्स सॉफ्टवेयर प्रक्रिया और सॉफ्टवेयर उत्पाद के विभिन्न पहलुओं के लिए उपाय प्रदान करते हैं। वे में विभाजित हैं -
- आवश्यकता मीट्रिक: लंबाई की आवश्यकताएं, पूर्णता
- उत्पाद मैट्रिक्स: कोड की लाइनें, ऑब्जेक्ट ओरिएंटेड मेट्रिक्स, डिज़ाइन और टेस्ट मेट्रिक्स
- प्रक्रिया मेट्रिक्स: मूल्यांकन और ट्रैक बजट, अनुसूची, मानव संसाधन।
Q.What is modularization?
A. मॉडर्नाइजेशन एक सॉफ्टवेयर सिस्टम को कई डिस्क्रिट मॉड्यूल में विभाजित करने की एक तकनीक है, जिसे स्वतंत्र रूप से कार्य करने की उम्मीद है।
Q.What is concurrency and how it is achieved in software?
A.एक साथ होने वाली घटनाओं या कार्यों की प्रवृत्ति को कंज्यूमर कहते हैं। सॉफ्टवेयर में, जब दो या अधिक प्रक्रियाएं एक साथ चलती हैं, तो उन्हें समवर्ती प्रक्रिया कहा जाता है।
उदाहरण
जब आप प्रिंट कमांड शुरू करते हैं और प्रिंटिंग शुरू होती है, तो आप एक नया एप्लिकेशन खोल सकते हैं।
Concurrency, कार्यान्वित की कई स्वतंत्र इकाइयों में सॉफ्टवेयर को विभाजित करके कार्यान्वित की जाती है, अर्थात् प्रक्रियाओं और थ्रेड्स, और उन्हें समानांतर में निष्पादित करना।
Q.What is cohesion?
A. सामंजस्य एक ऐसा उपाय है जो मॉड्यूल के तत्वों के बीच अंतर-निर्भरता की डिग्री को परिभाषित करता है।
Q.What is coupling?
A. युग्मन एक उपाय है जो एक कार्यक्रम के मॉड्यूल के बीच अंतर-निर्भरता के स्तर को परिभाषित करता है।
Q.Mentions some software analysis & design tools?
A. ये हो सकते हैं: DFDs (डेटा फ़्लो डायग्राम्स), स्ट्रक्चर्ड चार्ट्स, स्ट्रक्चर्ड इंग्लिश, डेटा डिक्शनरी, HIPO (पदानुक्रमित इनपुट प्रोसेस आउटपुट) आरेख, ईआर (एंटिटी रिलेशनशिप) आरेख और निर्णय तालिकाएँ।
Q.What is level-0 DFD?
A. उच्चतम अमूर्तता स्तर DFD को स्तर 0 DFD के रूप में भी जाना जाता है जिसे संदर्भ स्तर DFD भी कहा जाता है, जो संपूर्ण सूचना प्रणाली को सभी अंतर्निहित विवरणों को छिपाने वाले एक आरेख के रूप में दर्शाता है।
Q.What is the difference between structured English and Pseudo Code?
A. संरचित अंग्रेजी मूल अंग्रेजी भाषा है जिसका उपयोग प्रोग्रामिंग भाषा कीवर्ड का उपयोग करके प्रोग्राम मॉड्यूल की संरचना लिखने के लिए किया जाता है, जबकि, छद्म कोड प्रोग्रामिंग भाषा के अधिक करीब है और कोड के कुछ हिस्सों को लिखने के लिए देशी अंग्रेजी भाषा के शब्दों या वाक्यों का उपयोग करता है।
Q.What is data dictionary?
A.डेटा डिक्शनरी को मेटा-डेटा कहा जाता है। मतलब, यह डेटा के बारे में डेटा का भंडार है। डेटा डिक्शनरी का उपयोग सिस्टम में उपयोग होने वाले नाम और उनके संदर्भों को व्यवस्थित करने के लिए किया जाता है जैसे ऑब्जेक्ट्स और फाइलें उनके नामकरण सम्मेलनों के साथ।
Q.What is structured design?
A.संरचित डिजाइन समाधान के कई सुव्यवस्थित तत्वों में समस्या की अवधारणा है। यह समाधान के डिजाइन और 'विभाजन और जीत' की रणनीति पर आधारित है।
Q.What is the difference between function oriented and object oriented design?
A.फ़ंक्शन-उन्मुख डिज़ाइन कई छोटे उप-प्रणालियों से युक्त होता है जिन्हें फ़ंक्शन के रूप में जाना जाता है। प्रत्येक फ़ंक्शन सिस्टम में महत्वपूर्ण कार्य करने में सक्षम है। ऑब्जेक्ट ओरिएंटेड डिज़ाइन वास्तविक दुनिया की वस्तुओं (संस्थाओं), उनकी कक्षाओं (श्रेणियों) और वस्तुओं (कार्यों) पर काम करने वाले तरीकों के आसपास काम करता है।
Q.Briefly define top-down and bottom-up design model.
A. टॉप-डाउन मॉडल सिस्टम के सामान्यीकृत दृष्टिकोण से शुरू होता है और इसे और अधिक विशिष्ट लोगों के लिए विघटित करता है, जबकि नीचे-ऊपर वाला मॉडल सबसे विशिष्ट और बुनियादी घटकों के साथ शुरू होता है और उच्च स्तर के अमूर्त होने के लिए घटकों की रचना करता रहता है।
Q.What is the basis of Halstead’s complexity measure?
A. हालस्टीड की जटिलता माप कार्यक्रम के वास्तविक कार्यान्वयन पर निर्भर करती है और यह कार्यक्रम में उपयोग किए जाने वाले टोकन को माप के आधार के रूप में मानता है।
Q.Mention the formula to calculate Cyclomatic complexity of a program?
A. साइक्लोमैटिक जटिलता ग्राफ सिद्धांत के सूत्र का उपयोग करती है: V (G) = e - n + 2
Q.What is functional programming?
A.कार्यात्मक प्रोग्रामिंग प्रोग्रामिंग भाषा की शैली है, जो गणितीय फ़ंक्शन की अवधारणाओं का उपयोग करती है। यह गणितीय कार्यों के रूप में संगणना का साधन प्रदान करता है, जो कार्यक्रम की स्थिति के बावजूद परिणाम उत्पन्न करता है।
Q.Differentiate validation and verification?
A. सत्यापन जाँच करता है कि उत्पाद उपयोगकर्ता की आवश्यकताओं के अनुसार बनाया गया है जबकि सत्यापन जाँचता है कि उत्पाद को विकसित करने के लिए उचित कदम उठाए गए हैं या नहीं।
सत्यापन सही उत्पाद की पुष्टि करता है और सत्यापन पुष्टि करता है कि उत्पाद सही तरीके से बनाया गया है।
Q.What is black-box and white-box testing?
A.ब्लैक-बॉक्स परीक्षण की जांच करता है कि वैध इनपुट मान दिए जाने पर वांछित आउटपुट उत्पन्न होते हैं या नहीं। यह कार्यक्रम के वास्तविक कार्यान्वयन को सत्यापित नहीं करता है।
व्हाइट-बॉक्स परीक्षण न केवल वांछित और वैध आउटपुट के लिए जाँच करता है जब वैध इनपुट प्रदान किया जाता है, बल्कि यह भी जांचता है कि क्या कोड सही तरीके से लागू किया गया है।
मानदंड | ब्लैक बॉक्स परीक्षण | व्हाइट बॉक्स परीक्षण |
---|---|---|
सॉफ्टवेयर प्रोग्राम, डिजाइन और संरचना का ज्ञान आवश्यक है | नहीं | हाँ |
सॉफ्टवेयर कार्यान्वयन का ज्ञान आवश्यक है | नहीं | हाँ |
सॉफ्टवेयर पर यह परीक्षण कौन करता है | सॉफ्टवेयर परीक्षण कर्मचारी | सॉफ्टवेयर डेवलपर |
परीक्षक के लिए आधारभूत संदर्भ | आवश्यकताएँ विनिर्देशों | डिजाइन और संरचना विवरण |
Q.Quality assurance vs. Quality Control?
A. सॉफ्टवेयर को विकसित करते समय उचित प्रक्रिया का पालन किया जाता है या नहीं, इसकी जांच करने के लिए गुणवत्ता आश्वासन मॉनिटर करता है।
गुणवत्ता नियंत्रण सॉफ्टवेयर उत्पाद की गुणवत्ता बनाए रखने से संबंधित है।
Q.What are various types of software maintenance?
A. रखरखाव प्रकार हैं: सुधारात्मक, अनुकूली, पूर्ण और निवारक।
- Corrective
उपयोगकर्ताओं द्वारा स्पॉट की गई त्रुटियों को हटाना
- Adaptive
हार्डवेयर और सॉफ्टवेयर वातावरण में परिवर्तन से निपटने के लिए जहां सॉफ्टवेयर काम करता है
- Perfective maintenance
उपयोगकर्ता की मौजूदा या नई आवश्यकताओं में परिवर्तन लागू करना
- Preventive maintenance
भविष्य की समस्याओं से बचने के लिए उचित उपाय करना
Q.What is software re-engineering?
A.सॉफ्टवेयर री-इंजीनियरिंग उस तकनीक को अपग्रेड करने की प्रक्रिया है, जिस पर सॉफ्टवेयर की कार्यक्षमता को बदले बिना सॉफ्टवेयर का निर्माण किया जाता है। यह नवीनतम तकनीक के साथ सॉफ्टवेयर को बनाए रखने के लिए किया जाता है।
Q.What are CASE tools?
A.CASE का उद्देश्य कंप्यूटर एडेड सॉफ्टवेयर इंजीनियरिंग है। CASE उपकरण स्वचालित सॉफ़्टवेयर एप्लिकेशन प्रोग्राम्स के सेट होते हैं, जिनका उपयोग SDLC गतिविधियों को समर्थन, गति और स्मूथ करने के लिए किया जाता है।
आगे क्या है?
इसके अलावा, आप अपने पिछले असाइनमेंट के माध्यम से जा सकते हैं जो आपने विषय के साथ किया है और सुनिश्चित करें कि आप उन पर आत्मविश्वास से बोलने में सक्षम हैं। यदि आप नए हैं तो साक्षात्कारकर्ता को यह उम्मीद नहीं है कि आप बहुत जटिल प्रश्नों का उत्तर देंगे, बल्कि आपको अपनी मूल अवधारणाओं को बहुत मजबूत बनाना होगा।
दूसरा यह वास्तव में बहुत ज्यादा मायने नहीं रखता है अगर आप कुछ सवालों के जवाब नहीं दे सकते हैं लेकिन यह मायने रखता है कि आपने जो भी उत्तर दिया है, आपने आत्मविश्वास के साथ उत्तर दिया होगा। तो बस अपने साक्षात्कार के दौरान आत्मविश्वास महसूस करें। हम एक अच्छे साक्षात्कारकर्ता और आपके भविष्य के प्रयास के लिए बहुत बहुत शुभकामनाएँ। चियर्स :-)