मेरे द्वारा विकसित किए गए सभी WPF एप्लिकेशन में AppDomain.CurrentDomain.UnhandledException
पर सदस्यता लेने वाला एक वैश्विक अपवाद हैंडलर है जो इसे ढूंढने वाली सभी चीज़ों को लॉग करता है और फिर एक संवाद बॉक्स दिखाता है जो उपयोगकर्ता को लेखक से संपर्क करने के लिए कहता है, जहां लॉग फ़ाइल आदि है। यह बहुत अच्छी तरह से काम करता है और दोनों ग्राहक और मैं इसके साथ बहुत खुश हैं क्योंकि यह तेजी से समस्याओं को ठीक करने की अनुमति देता है।मिश्रित एप्लिकेशन में बफर ओवरफ़्लो अपवाद पर जानकारी कैसे प्राप्त करें?
हालांकि मिश्रित WPF/C#/CLI/C++ अनुप्रयोग के विकास के दौरान कभी-कभी एप्लिकेशन क्रैश होते हैं जो इसे उपरोक्त अपवाद हैंडलर तक नहीं बनाते हैं। इसके बजाए, एक मानक विंडोज़ संवाद बॉक्स कहता है कि "XXX ने काम करना बंद कर दिया है" पॉप अप करता है। विवरण में यह जैसे
Problem Event Name: BEX
Application Name: XXX.exe
Fault Module Name: clr.dll
...
यह ज्यादातर होता है जब वापस umanaged कोड के भीतर से एक प्रबंधित फ़ंक्शन को कॉल से पता चलता है, और उस समारोह स्क्रीन अद्यतन करता है जब। मुझे समस्या के मूल कारण को समझने में मुझे लंबा समय नहीं लगा, लेकिन केवल इसलिए कि मैं अपनी मशीन पर दुर्घटना को पुन: पेश कर सकता हूं और डीबगर को हुक कर सकता हूं: सभी अवसरों में देशी धागा अभी भी फ़ंक्शन पॉइंटर को कॉल करने के बिंदु पर था प्रबंधित प्रतिनिधि जो सीधे सी #/डब्ल्यूपीएफ कोड में कॉल करता है।
वास्तविक समस्या तब होगी जब यह क्लाइंट मशीन पर होता है: यह देखते हुए कि आमतौर पर क्लाइंट सबसे अच्छा त्रुटि संवाददाता नहीं होते हैं, यह पता लगाने में बहुत लंबा लगता है कि क्या गलत है, जब वे मुझे प्रदान कर सकते हैं उपरोक्त विवरण।
प्रश्न: मैं इस तरह के दुर्घटनाओं के लिए अधिक जानकारी प्राप्त करने के लिए क्या कर सकता हूं? क्या इस तरह एक अपवाद प्राप्त करने का कोई तरीका है एक कस्टम त्रुटि हैंडलर वैसे भी? या एक प्रक्रिया डंप प्राप्त करें? जब msvcr100_clr0004.dll और clr.dll (धागा जहां तोड़ने occurrs पर लोड) के लिए प्रतीकों लोड हो रहा है, कॉल स्टैक इस तरह है:
msvcr100_clr0400.dll!__crt_debugger_hook()
clr.dll!___report_gsfailure() + 0xeb bytes
[email protected]() + 0x8 bytes
clr.dll!CrawlFrame::CheckGSCookies() + 0x2c3b72 bytes
मैं किसी भी तरह __crt_debugger_hook में कुछ देशी सी ++ कोड हुक कर सकते हैं() (उदाहरण के लिए एक मिनीडम्प लिखने के लिए)? जो मुझे एक अतिरिक्त प्रश्न की ओर ले जाता है: CheckGSCookies
किसी मशीन पर कोई डीबगर स्थापित नहीं होता है, क्या यह अभी भी वही कोड कॉल करेगा?
अद्यतन कोड पर कुछ स्पष्टीकरण:। देशी सी ++ एक CLI प्रतिनिधि (जो करने के लिए एक देशी समारोह सूचक GetFunctionPointerForDelegate
जो बारी में एक सी # System.Action कॉल का उपयोग कर प्राप्त किया जाता है कहता है यह कार्रवाई एक स्ट्रिंग (एक WPF करने के लिए बाध्य अद्यतन करता है लेबल) और एक PropertyChanged घटना उठाती है। यह किसी भी तरह जब एक अनाम धागा है कि मेरे कोड में सीधे नहीं बनाया गया था में बहुत तेजी से अद्यतन करना) एक बफर अतिप्रवाह का आह्वान (।
अद्यतनSetUnhandledExceptionFilter
है, जो कुछ भी नहीं किया में देख सबसे पहले, मुझे this nifty article मिला कि यह कोई अपवाद कैसे पकड़ सकता है। यह काम करता है, और मैं अपवाद में एक मिनीडम्प लिखने में सक्षम था। उस प्रक्रिया का उपयोग करके स्थापित इल्टर। डंप मूल रूप से एक ही जानकारी देता है जो डीबगर को हुकिंग करता है: वास्तविक समस्या यह प्रतीत होती है कि स्थिति स्ट्रिंग को ओवरराइट किया जा रहा है (मूल धागे से बुलाया जा रहा है) जबकि एक ही समय में ui धागे से पढ़ा जा रहा है। सभी अच्छे उत्तर जैसे, लेकिन इसे डेल हुकिंग की आवश्यकता होती है जो चीजों को हल करने के लिए मेरी पसंदीदा विधि नहीं है। एक और तरीका अभी भी अच्छा होगा।
यदि मैं गलत हूं तो मुझे सही करें: 1. लक्ष्य प्लेटफ़ॉर्म विंडोज है। 2 आप एक एप्लिकेशन-व्यापी अनहैंडेड अपवाद फ़िल्टर स्थापित कर रहे हैं। 3. आप कुछ धागे बनाते हैं और कुछ डीएलएल गतिशील रूप से लोड करते हैं। 4. आप कुछ डीएलएल कार्यों को कॉल करते हैं और ये फ़ंक्शंस अपवाद फेंकते हैं जो इसे आपके हैंडलर में नहीं बनाते हैं। क्या वो सही है? साथ ही, ये अपवाद आपके धागे में से या डीडीएल के कार्यों द्वारा बनाए गए (संभवतः) धागे में होते हैं? – lapk
@AzzA 1. हां 2. हां, लेकिन CurrentDomain.UnhandledException का उपयोग करके, सुनिश्चित नहीं है कि यह पर्याप्त है 3. हां 4. अद्यतन – stijn
अपडेट करने के लिए देखें: 1. 'CurrentDomain.UnhandledException' के बजाय' SetUnhandledExceptionFilter 'WinAPI का उपयोग करने का प्रयास करें (हालांकि, मैं seriosuly संदेह है कि यह उपरोक्त WinAPI के आसपास एक रैपर है)। 2. ऐसा लगता है कि आप जो डीएलएल गतिशील रूप से लोड करते हैं, वे हैंडलर को अपने स्टार्ट-अप में डिफ़ॉल्ट न्यूल पर रीसेट कर सकते हैं। जिस बिंदु को मैं बनाने की कोशिश कर रहा हूं वह यह है कि आपको डीएलएल लोड होने के बाद अपना फ़िल्टर इंस्टॉल करना होगा, यह ध्यान में रखते हुए कि वे देरी से लोड हो सकते हैं - क्या आप उन्हें अपने कोड के अंदर लिंकर या 'लोड लाइब्रेरी' का उपयोग करके लोड कर रहे हैं? – lapk