मुझे आश्चर्य है कि क्या कोई कारण हैं (स्रोत कोड को छोड़कर) क्यों डेवलपर्स विजुअल स्टूडियो 2008 में "अप्रयुक्त Usings
" सुविधा का उपयोग करते हैं?सी # में निर्देशों का उपयोग करके अप्रयुक्त क्यों हटाएं?
उत्तर
कुछ कारण हैं जिन्हें आप बाहर ले जाना चाहते हैं।
- यह व्यर्थ है। वे कोई मूल्य नहीं जोड़ते हैं।
- यह भ्रमित है। उस नामस्थान से क्या उपयोग किया जा रहा है?
- यदि आप नहीं करते हैं, तो आप धीरे-धीरे व्यर्थ
using
कथन जमा करेंगे क्योंकि आपका कोड समय के साथ बदलता है। - स्थिर विश्लेषण धीमा है।
- कोड संकलन धीमा है।
दूसरी तरफ, उन्हें छोड़ने के कई कारण नहीं हैं। मुझे लगता है कि आप उन्हें हटाने के प्रयास को स्वयं बचाते हैं। लेकिन अगर आप आलसी हैं, तो आपको बड़ी समस्याएं हैं!
एक अच्छा प्रोग्रामर आलसी है, वह काम को अधिकतम करने के लिए अधिकतम नहीं करता है। : डी –
कोडरश आपको सभी अप्रयुक्त लोगों को एक माउसक्लिक के साथ स्थानांतरित करने की अनुमति देगा। – BenAlabaster
मैं इस बात से सहमत नहीं हूं कि एक अच्छा प्रोग्रामर आलसी है, लेकिन मैं आपके बयान की भावना से सहमत हूं। एक अच्छा प्रोग्रामर उन्हें अपने कोड को साफ रखने के लिए हटा देगा और इस तरह अपने और दूसरों के लिए भविष्य के काम/समस्याओं/मुद्दों से बच जाएगा। – Allan
कोड संकलित करता है।
इसे वापस करने के लिए कोई सबूत नहीं मिला? – cjk
ओह सीके - आपने मुझे फिर से पकड़ा। मैंने झूठ बोला। अनावश्यक पाठ को हटाने से वास्तव में कोड संकलित धीमा हो जाता है। इसके बारे में सोचें :) –
@ck: मैंने सत्यापित किया है कि काम पर एक परियोजना से बयान का उपयोग करके अप्रयुक्त उपयोग को हटाने में एक उल्लेखनीय राशि द्वारा संकलित समय में सुधार हुआ है। बेशक यह होगा - हार्ड ड्राइव से पढ़ने के लिए कम बाइट्स। – configurator
मैं काफी विपरीत कहूंगा - बयान का उपयोग करके अनावश्यक, अनावश्यक को हटाने में बहुत मददगार है।
कल्पना कीजिए कि आपको अपने कोड पर 3, 6, 9 महीने में वापस जाना होगा - या किसी और को अपना कोड लेना होगा और इसे बनाए रखना होगा।
यदि आपके पास वास्तव में आवश्यक कथन का उपयोग करने की एक बड़ी लंबी कपड़े धोने की सूची है, तो कोड को देखकर काफी भ्रमित हो सकता है। उस नाम का उपयोग क्यों नहीं किया जा रहा है, अगर उस नामस्थान से कुछ भी नहीं उपयोग किया जाता है ??
मुझे लगता है कि एक पेशेवर माहौल में दीर्घकालिक रखरखाव के मामले में, मैं दृढ़ता से सुझाव देता हूं कि आप अपना कोड जितना संभव हो सके साफ रखें - और इसमें इससे अनावश्यक सामान डंपिंग शामिल है। कम अव्यवस्था कम भ्रम और इस प्रकार उच्च रखरखाव के बराबर होती है।
मार्क
कम Intellisense पॉपअप (विशेषकर यदि नामस्थान एक्सटेंशन तरीकों के बहुत सारे होते हैं) में विकल्प।
सैद्धांतिक रूप से इंटेलिजेंस भी तेज होना चाहिए।
+1। यह स्टार्टअप पर वास्तव में धीमा है (मैं नियमित रूप से "बिल्डिंग कैश, बाद में पुनः प्रयास करें") देखता हूं, इसलिए यह वास्तव में महत्वपूर्ण हो सकता है। समय संकलित करें कि हर कोई इसके बारे में बात करता है ... मुझे अभी तक संख्याएं देखने की ज़रूरत नहीं है। – Luc
ऐसा लगता है कि यह एक बहुत ही समझदार सवाल है, जिसका जवाब लोगों द्वारा जवाब देने के लिए काफी तेज तरीके से किया जा रहा है।
मैं कहूंगा कि स्रोत कोड में कोई भी परिवर्तन उचित होना चाहिए। इन परिवर्तनों में छिपी हुई लागत हो सकती है, और सवाल रखने वाला व्यक्ति इस बारे में जागरूक होना चाहता था। उन्होंने एक आलसी के रूप में, "आलसी" कहने के लिए नहीं कहा था।
मैंने अभी रिशेर्पर का उपयोग करना शुरू कर दिया है, और यह उस परियोजना पर चेतावनी और स्टाइल संकेत देना शुरू कर रहा है जिसके लिए मैं ज़िम्मेदार हूं। उनमें से निर्देशक का उपयोग करके अनावश्यक हटाने, लेकिन अनावश्यक क्वालीफायर, पूंजीकरण और कई अन्य लोगों को भी हटा दिया जाता है। मेरा आंत वृत्ति कोड को साफ करना और सभी संकेतों को हल करना है, लेकिन मेरा व्यवसाय प्रमुख मुझे अन्यायपूर्ण परिवर्तनों के खिलाफ चेतावनी देता है।
हम एक स्वचालित निर्माण प्रक्रिया का उपयोग करते हैं, और इसलिए हमारे एसवीएन भंडार में कोई भी परिवर्तन परिवर्तन उत्पन्न करेगा जो हम परियोजनाओं/बग/मुद्दों से लिंक नहीं कर सकते हैं, और स्वचालित निर्माण और रिलीज को ट्रिगर करेंगे जो पिछले संस्करणों में कोई कार्यात्मक परिवर्तन नहीं पहुंचाएगा ।
अगर हम अनावश्यक क्वालिफायर को हटाने को देखो, यह संभवतः भ्रम डेवलपर्स वर्गों के रूप में हमारे डोमेन और डेटा परतों केवल क्वालिफायर द्वारा विभेदित होते हैं करने के लिए हो सकता है।
यदि मैं anachronyms (यानी एबीसीडी -> एबीसीडी) के पूंजीकरण के उचित उपयोग को देखता हूं तो मुझे यह ध्यान रखना होगा कि Resharper किसी भी एक्सएमएल फाइलों को दोबारा प्रतिक्रिया नहीं देता है जिसे हम उस संदर्भ वर्ग नामों का उपयोग करते हैं।
तो, ये संकेत का पालन नहीं कर के रूप में सीधी-सपाट यह प्रतीत होता है, और सम्मान के साथ व्यवहार किया जाना चाहिए के रूप में है।
अच्छा प्वाइंट, लेकिन आपको यह भी नहीं भूलना चाहिए कि स्वच्छ असम्बद्ध कोड का उपयोग रखरखाव को बढ़ाता है जो एक व्यावसायिक उद्देश्य भी है। आपको दोनों को वजन करना होगा। आदर्श रूप में आप रिलीज के ठीक बाद इस तरह के रिफैक्टरिंग करना चाहते हैं ताकि आप एक नया शुरू करने के लिए जितना संभव हो सके स्लेट को साफ कर सकें और अंतिम प्रतिक्रियाओं को पकड़ने के लिए पर्याप्त समय हो। –
यह भी झूठी परिपत्र निर्भरता को रोकने में मदद करता है, यह मानते हुए आप भी अप्रयुक्त usings हटाने के बाद अपनी परियोजना से कुछ dll/परियोजना संदर्भ निकाल पा रहे हैं।
उन्हें निकालें। समय और भ्रम की बचत के बारे में सोचने और आश्चर्य करने के लिए कम कोड। मेरी इच्छा है कि ज्यादा लोग चीजें, साफ और साफ रहें। यह आपके कमरे में गंदे शर्ट और पैंट होने जैसा है। यह बदसूरत है और आपको आश्चर्य है कि यह क्यों है।
कारणों को पहले से ही दिए गए के अलावा, यह अनावश्यक नामकरण संघर्ष से बचाता है।
using System.IO;
using System.Windows.Shapes;
namespace LicenseTester
{
public static class Example
{
private static string temporaryPath = Path.GetTempFileName();
}
}
इस कोड संकलन नहीं है क्योंकि दोनों नामस्थान System.IO और System.Windows.Shapes प्रत्येक एक वर्ग पथ कहा जाता है: इस फाइल पर विचार करें। हम पूर्ण वर्ग पथ का उपयोग कर इसे ठीक कर सकता है
private static string temporaryPath = System.IO.Path.GetTempFileName();
या हम बस लाइन using System.Windows.Shapes;
को दूर कर सकता है।
कम से कम सिद्धांत में, यदि आपको सी # .cs फ़ाइल (या कोई एकल प्रोग्राम स्रोत कोड फ़ाइल) दी गई थी, तो आपको कोड को देखने और एक ऐसा वातावरण बनाने में सक्षम होना चाहिए जो इसकी आवश्यक चीज़ों को अनुकरण करता है। कुछ संकलन/पार्सिंग तकनीक के साथ आप इसे स्वचालित रूप से करने के लिए एक टूल भी बना सकते हैं। यदि यह आपके द्वारा कम से कम दिमाग में किया जाता है, तो आप यह सुनिश्चित कर सकते हैं कि कोड कोड कहने वाले सभी चीजों को समझें।
अब विचार करें, अगर आपको 1000 using
निर्देशों के साथ .cs फ़ाइल दी गई थी जो वास्तव में केवल 10 का उपयोग किया गया था। जब भी आप किसी ऐसे प्रतीक को देखते हैं जो बाहरी दुनिया के संदर्भ में कोड में पेश किया गया है, तो आपको यह पता लगाने के लिए उन 1000 लाइनों से गुज़रना होगा। यह स्पष्ट रूप से उपर्युक्त प्रक्रिया को धीमा कर देता है। तो यदि आप उन्हें 10 तक कम कर सकते हैं, तो इससे मदद मिलेगी!
मेरी राय में, सी # using
निर्देश बहुत कमजोर है, क्योंकि आप सामान्यता खोए बिना एकल जेनेरिक प्रतीक निर्दिष्ट नहीं कर सकते हैं, और आप विस्तार विधियों का उपयोग करने के लिए using
उपनाम निर्देश का उपयोग नहीं कर सकते हैं। जावा, पायथन और हास्केल जैसी अन्य भाषाओं में यह मामला नहीं है, उन भाषाओं में आप बाहरी दुनिया से जो कुछ भी चाहते हैं उसे निर्दिष्ट करने में सक्षम हैं। लेकिन तब घटना, मैं जब भी संभव हो using
उपनाम का उपयोग करने का सुझाव दूंगा।
हाल ही में मैं एक और कारण है कि अप्रयुक्त आयात को हटाने काफी उपयोगी और महत्वपूर्ण है मिला है।
कल्पना कीजिए कि आपके पास दो असेंबली हैं, जहां एक दूसरे का संदर्भ देता है (अब के लिए पहले A
और संदर्भित B
) को कॉल करें। अब जब आपके पास ए में कोड है जो बी पर निर्भर करता है तो सबकुछ ठीक है। हालांकि आपकी विकास प्रक्रिया में कुछ स्तर पर आप ध्यान देते हैं कि आपको वास्तव में उस कोड की आवश्यकता नहीं है, लेकिन आप उस कथन का उपयोग छोड़ दें जहां यह था।अब आप न केवल एक अर्थहीन using
-directive लेकिन यह भी एक विधानसभा संदर्भB
को जो कहीं भी नहीं किया जाता है, लेकिन अप्रचलित निर्देश में की है। यह A
संकलित करने के लिए आवश्यक समय की मात्रा को बढ़ाता है, क्योंकि B
को भी लोड किया जाना है।
तो यह न केवल क्लीनर और कोड पढ़ने में आसान है बल्कि उत्पादन-कोड में असेंबली-संदर्भों को बनाए रखने पर भी एक मुद्दा है, जहां उन सभी संदर्भित असेंबली भी मौजूद नहीं हैं।
अंततः हमारे एक्सपैपल में हमें बी और ए को एक साथ भेजना पड़ा, हालांकि बी को ए में कहीं भी नहीं बल्कि using
-क्शन में उपयोग किया जाता था। यह बड़े पैमाने पर A
जब लोड हो रहा है विधानसभा के क्रम -performance को प्रभावित करेगा।
- 1. नई सी # फाइलों में निर्देशों का उपयोग करके डिफ़ॉल्ट
- 2. अप्रयुक्त संदर्भों को हटाएं (! = "उपयोग")
- 3. पूरे असेंबली में अप्रयुक्त उपयोग हटाएं
- 4. एसएसई निर्देशों का उपयोग
- 5. निर्देशों का उपयोग करके अनावश्यक सी # को क्यों हटाया जाना चाहिए?
- 6. मैं अप्रयुक्त # अंतर्निहित निर्देशों को कैसे ढूंढूं?
- 7. सी # परियोजना-व्यापी उपनाम निर्देशों का उपयोग
- 8. डेटाग्रिड व्यू: अप्रयुक्त स्थान हटाएं?
- 9. विवरण Roslyn स्क्रिप्ट/कोड का उपयोग करके सॉर्ट करें और हटाएं (अप्रयुक्त)?
- 10. पुनर्विक्रेता के बिना सी # परियोजना में अप्रयुक्त संदर्भ (! = Usings) हटाएं?
- 11. निर्देशों का उपयोग करके कई कैसे लिखते हैं?
- 12. समाधान में अप्रयुक्त सीएस-फाइलों को हटाएं
- 13. एक बड़े TObjectList का उपयोग करके और अप्रयुक्त भाग
- 14. "अप्रयुक्त संदर्भों को हटाएं" का उद्देश्य क्या है
- 15. अप्रयुक्त सी ++
- 16. एएसपी.नेट में सी # का उपयोग करके डबल
- 17. सी # संकलक निर्देशों
- 18. विज़ुअल सी ++ में इसे हटाएं और हटाएं?
- 19. अप्रयुक्त गिट शाखाओं को कैसे हटाएं
- 20. क्यों सी # में String.Concat() का उपयोग करें?
- 21. एमएएसएम में अप्रयुक्त .CONST डेटा को कैसे हटाएं?
- 22. टेम्पलेट्स का उपयोग करके किसी भी कंटेनर को हटाएं
- 23. केवल प्राथमिक कुंजी का उपयोग करके कैसे हटाएं?
- 24. MySQL अद्यतन का उपयोग करके हाइफ़न को कैसे हटाएं?
- 25. सहेजने पर दृश्य स्टूडियो 2008 "निर्देशों का उपयोग करके सॉर्ट करें" को स्वचालित रूप से कॉल करें?
- 26. सी ++ पॉइंटर्स का ऐरे: हटाएं या हटाएं []?
- 27. अप्रयुक्त गेटटेक्स्ट तारों को स्वचालित रूप से कैसे हटाएं?
- 28. उद्देश्य सी कोडिंग दिशा निर्देशों
- 29. सी # में निर्देशों का उपयोग करने की "साफ" सूची बनाए रखने के क्या फायदे हैं?
- 30. सी में मैक्रोज़ का उपयोग क्यों करें?
मुझे विश्वास है कि दृश्य स्टूडियो के लिए PowerCommands की एक विशेषता है, दृश्य स्टूडियो के ही नहीं। –
वीएस -2008 में यह निश्चित रूप से एक विशेषता है (वीएस के उपयोग कथन को सॉर्ट करने की क्षमता के साथ)। – Richard
@ होसम: पावरकॉमैंड्स आपको पूरी परियोजना/समाधान के लिए ऐसा करने में सक्षम बनाता है। प्रति फ़ाइल करना यह वीएस की एक विशेषता है। – configurator