कोड पठनीयता के अलावा, यदि बयानों के बहुत सारे उपयोग करना बुरा क्यों है?बयानों के बहुत से उपयोग करने के नुकसान
उत्तर
यदि आपके पास एक दूसरे के बाद एक बयान है, तो एक स्विच केस स्टेटमेंट अधिक उपयोगी है। कम से कम इसमें प्रत्येक संभावित अपरिपक्व के लिए एक निश्चित प्रतिक्रिया समय होता है क्योंकि इसे सभी बयानों के माध्यम से गिरने की आवश्यकता नहीं होती है।
अगर (और बाकी) बयान आम तौर पर दर्शाता
एक 'स्विच' कथन में निश्चित प्रतिक्रिया समय नहीं है (कम से कम सी # में नहीं)। ऐसा कहकर, इस तरह के अति-सूक्ष्म-अनुकूलन के बारे में चिंता करना हर किसी के लिए समय बर्बाद है। – LukeH
@LukeH: मैंने वास्तव में कल अपने अधिकांश ऐप में शाखा दंडों को ट्रैक करने और उन्हें 250 एमएम तक पहुंचने के लिए 50 एमएमएस तक पहुंचने के लिए शाखाओं के बिना एल्गोरिदम के साथ उन्हें हटा दिया। – Crashworks
@ क्रैशवर्क: यही कारण है कि मैंने केवल एक कंबल * "सबको" * के बजाय * "बहुत ज्यादा सब कुछ" * कहा। मुझे संदेह है कि आप उन अपवादों में से एक हैं जो नियम साबित करते हैं। – LukeH
if(A)
{
}else
if(B)
{
}else
if(C)
{
}else
if(D)
{
}else
{ }
सभी if
रों अभी भी हो "गणना" करने के लिए यह की तरह कुछ कर रही है "हे (एन)" होगा। जब संभव हो तो इसे टालना चाहिए और switch(Lalala)
यदि आप 'else' का उपयोग कर रहे हैं तो शेष स्थिति के बाद' if' s का मूल्यांकन नहीं किया जाता है। यह केवल खराब मामला है जब कोई 'if' मैचों और अंतिम 'else' निष्पादित नहीं किया जाता है। – TheVillageIdiot
@TheVillage, हां यही वह है जिसका मैं जिक्र कर रहा हूं। डिफ़ॉल्ट: स्विच में मामला। जैसे। अगर सी मिलान की स्थिति होगी, तो ए और बी को अभी भी मूल्यांकन करना होगा। लेकिन स्विच के साथ हम सीधे "कूद" कर सकते हैं सी – Muggen
@ हेनक, माफ़ कीजिए मैं सिर्फ एक छात्र हूं। – Muggen
में बाहर refactor करने की आवश्यकता का एक बहुत है, यह एक खोजने के लिए और अधिक कुशल है बिल्कुल शाखाओं से बचने के लिए रास्ता; इसे if
कथन का नुकसान माना जा सकता है।
एक और संभावना - यह निर्भर करता है कि अगर कथन क्या कर रहे हैं। कुछ मामलों में, वे निर्णय ले सकते हैं जो उचित ढंग से डिज़ाइन किए गए क्लास पदानुक्रम द्वारा बेहतर होते हैं।
क्या आप कुछ उदाहरण पोस्ट कर सकते हैं यदि आपको बताए गए बयान खराब हैं?
प्रत्येक अगर आप लिखते हैं तो आपके द्वारा परीक्षण किए जाने वाले कोड पथों की संख्या बढ़ जाती है।
यदि कथन पाइपलाइन में एक स्टॉल का उत्पादन कर सकता है। आप पाइपलाइन खतरों here के बारे में पढ़ सकते हैं। इसलिए, बहुत ही महत्वपूर्ण महत्वपूर्ण अनुप्रयोगों के लिए एक बड़े लूप में बयान देने के लिए बहुत अच्छा विचार नहीं है। आधुनिक प्रोसेसर में शाखा भविष्यवाणी के बारे में this लेख, और शर्तों के विभिन्न बिंदुओं के बेंचमार्क भी देखें।
इसके अलावा, मुझे लगता है कि बहुत से लोग केस स्टेटमेंट के बारे में बात करते हैं। this एसओ धागा की जांच करें।
और अंत में, wiki article पाइपलाइन के बारे में जो शायद हर प्रोग्रामर को पढ़ना चाहिए था।
उम्मीद है कि यह मदद करता है।
चुसदाद सही है। स्विच संरचना कई से बेहतर है अगर अन्यथा। अगला दृष्टिकोण एनम का उपयोग स्विच कुंजी के रूप में करना है। यदि आप अपने स्विच में enum तत्वों में से एक का उल्लेख करना भूल गए हैं तो इस मामले में आपको चेतावनी मिलती है।
लेकिन यदि आप enum और switch का उपयोग कर रहे हैं, तो बेहतर डिज़ाइन के लिए आगे बढ़ें: बिल्कुल स्विच हटाएं!
अपने enum में अमूर्त व्यापार विधि घोषित करें। प्रत्येक enum तत्व के लिए इसे लागू करें। स्विच लागू करने के बजाय enumElement.theMethod() कॉल करें।
यहां एक उदाहरण है।
Foo.valueOf(System.getProperty("foo")).foo();
निम्नलिखित के साथ इस लाइन की तुलना करें::
enum Foo {
ONE {
public void foo() {
// do something
}
},
TWO {
public void foo() {
// do something
}
},
;
public abstract void foo();
}
यहाँ कोड इस का उपयोग करता है है
String foo = System.getProperty("foo");
if("ONE".equals(foo)) {
//.....
} else if("ONE".equals(foo)) {
//.....
} else {
//.....
}
मुझे लगता है कि कोई टिप्पणी नहीं की आवश्यकता है।
ठीक है, मुझे सवाल पूछना है, "क्या विरोध है"?
यदि आप स्विच स्टेटमेंट के विपरीत हैं, तो साथ ही पठनीयता कभी-कभी अधिक कुशल हो सकती है। एक निश्चित रूप से शाखाओं के नीचे एक नियम (निश्चित रूप से सी # में, दूसरों में होने की संभावना) के रूप में इसे संकलित करते समय केवल बयानों की श्रृंखला में बदल दिया जाएगा, लेकिन उस संख्या से परे इसे एक हैश-आधारित लुकअप में बदल दिया जाएगा और कूदो औसत मामले पर तेजी से होने की संभावना है।
वैकल्पिक रूप से, यदि आपके पास विभिन्न मामलों की सापेक्ष आवृत्ति का अच्छा ज्ञान है, तो आप कथन के सेट के साथ अधिक कुशल हो सकते हैं। जैसे यदि 95% मामले पहली शाखा से मेल खाते हैं, तो 4% दूसरे और 1% मैच बाकी के साथ मिलते हैं, यह 95% मामलों के लिए एक तुलना करके बेहतर प्रदर्शन कर सकता है और शायद उस मामले में ब्रांचिंग भी नहीं कर सकता है।
तो। शायद इस मामले में एक दक्षता लाभ है।
फिर भी, पठनीयता बहुत नरक के लिए मायने रखती है। एक चरम उदाहरण के रूप में, एक ट्यूरिंग-पूर्ण भाषा है जिसे केवल यह देखने के लिए डिज़ाइन किया गया था कि ट्यूरिंग-पूर्ण भाषा के लिए एक कंपाइलर कितना छोटा हो सकता है। इस डिजाइनर ने भाषा "brainf ** k" नाम दिया है। वास्तविक प्रोग्रामिंग में पठनीय कोड के महत्व पर यह स्वयं ही एक महान टिप्पणी है।
अब, अगर बड़ी संख्या में बयानों के साथ एक बड़ा मुद्दा यह है कि यह अक्सर इंगित करता है कि आप उन लोगों के माध्यम से कुछ मॉडलिंग कर रहे हैं यदि बयान जो वर्ग पदानुक्रम के साथ बेहतर तरीके से मॉडलिंग किए जा सकते हैं। एक तरह से यह पठनीयता पर एक और ले लेता है (यह मानते हुए कि कार्यक्रम किसी भी तरह से काम करता है)। हालांकि, यह पूरी तरह से कार्यक्रम की पठनीयता - और समझदारी के बारे में है। यह प्रोग्राम, एक्स्टेंसिबिलिटी के मानसिक मॉडल पर बड़े पैमाने पर प्रभाव डालेगा और न केवल यह सुनिश्चित करेगा कि आप इसे कितनी अच्छी तरह से बनाए रख सकते हैं, लेकिन आप इसके साथ जितना संभव हो उतना गर्भ धारण करेंगे। यह आसानी से ऐसे कार्यक्रम के बीच अंतर हो सकता है जो विरासत समय-सिंक बन जाता है जब तक कोई इससे छुटकारा पाने के लिए काम नहीं करता है, और जो निवेश पर वापसी जारी रखने के लिए बढ़ता है।
यदि आप स्वयं को उसी स्थिति के लिए if
कथन लिखते हैं, तो यह प्रकार पदानुक्रम के उस हिस्से को बनाने के लिए और अधिक रखरखाव होगा।
कारण यह है कि यदि इस स्थिति के लिए तर्क बदलता है, तो आपको इसका उपयोग करने वाले प्रत्येक if
कथन का शिकार करना होगा और इसे संशोधित करना होगा।
यदि वह तर्क क्लास पदानुक्रम में समाहित है, तो आपको केवल इसे एक बार बदलना होगा।
- 1. Basic4Android का उपयोग करने के नुकसान?
- 2. क्या बयानों और यदि बयानों में एकाधिक का उपयोग करने के बीच कोई अंतर है?
- 3. sql_variant का उपयोग करने के नुकसान क्या हैं?
- 4. तुलना बयानों के जावास्क्रिप्ट न्यूनीकरण
- 5. बयानों में चर के दायरे
- 6. स्टोरीबोर्डिंग का उपयोग करने के फायदे और नुकसान?
- 7. AF_UNSPEC का उपयोग करने के नुकसान/जोखिम क्या होंगे?
- 8. ओपनआईडी का उपयोग करने के फायदे और नुकसान क्या हैं?
- 9. एआरसी का उपयोग करने के फायदे और नुकसान क्या हैं?
- 10. SQLDataReader का उपयोग करने के कुछ लाभ/नुकसान क्या हैं?
- 11. मेवेन का उपयोग करने के फायदे/नुकसान क्या हैं?
- 12. प्रारूपण/बयानों का उपयोग कर (सी #) के लिए खरोज
- 13. कर्सर बंद करने के एंड्रॉइड नुकसान
- 14. Force.com प्लेटफ़ॉर्म के नुकसान
- 15. जाने बयानों
- 16. कोड कवरेज के नुकसान
- 17. UIImage गुणवत्ता के नुकसान के बिना आकार
- 18. तैयार बयानों के साथ एसक्यूएल इंजेक्शन?
- 19. स्टाइलिंग उद्देश्यों के लिए खाली div टैग का उपयोग करने के नुकसान?
- 20. नुकसान
- 21. एंड्रॉइड अनुप्रयोगों के नुकसान
- 22. विस्तार विधियों के नुकसान?
- 23. नेट नामस्थान और बयानों का उपयोग कर
- 24. शीर्षलेख फ़ाइलों के फायदे/नुकसान
- 25. फ़ाइलों को दो प्रक्रियाओं के बीच संवाद करने के साधन के रूप में उपयोग करने के सभी नुकसान क्या हैं?
- 26. बिल्डर डिजाइन पैटर्न के नुकसान
- 27. MySQL पंक्ति लॉकिंग के नुकसान
- 28. रचनाकारों में काम करने के एक नुकसान में संदेह
- 29. आगे की घोषणा के नुकसान?
- 30. तैयार बयानों पर टाइमआउट डालने
अधिकांश कार्यक्रमों में बहुत सारे if-statement हैं। मैंने कभी नहीं सुना है कि यह बुरा है। क्या आप शायद * गहराई से घोंसला * if-statement का जिक्र कर रहे हैं? –
मुझे नहीं पता, है ना? किस संदर्भ में? –
एक समस्या यह है कि आप बहुत सारे कोड पथ पेश कर रहे हैं। इससे कोड का परीक्षण करना मुश्किल हो जाता है। प्रत्येक पथ को अलग से ट्रिगर करना मुश्किल हो सकता है। उल्लेखनीय रणनीति जैसे प्रयोग योग्य डिजाइन पैटर्न खोजने के लिए बेहतर है। इससे आपको प्रत्येक व्यक्तिगत कोड पथ का परीक्षण करना आसान हो जाएगा। –