2012-06-29 21 views
6

पर्यावरण की संकलक बग है: माइक्रोसॉफ्ट विजुअल स्टूडियो 2010 SP1 Preminum (10.0.40219.1 SP1Rel), Windows XP SP3यह एक माइक्रोसॉफ्ट कुलपति ++ 2010 "नई ऑटो (enum_type)"

VC10 संकलक समर्थन ऑटो कीवर्ड, लेकिन साथ प्रयुक्त प्रकार से संबंधित जानकारी हमेशा गणना के लिए सही नहीं लगता है।

उदाहरण:

#include <type_traits> 

enum fruit_t 
{ 
    apple = 100, 
    banana = 200, 
}; 

int main() 
{ 
    const auto pa = new auto(banana); 
    const auto pb = new fruit_t(banana); 
    static_assert(std::is_same<decltype(pa), decltype(pb)>::value, "not same!"); 
    delete pb; 
    delete pa; 
} 

कोड के ऊपर कोई संकलक-टाइम त्रुटि या रनटाइम त्रुटि होना चाहिए। लेकिन मुझे आश्चर्य है कि, यह किसी भी त्रुटि या चेतावनी के बिना ठीक संकलित करता है, लेकिन सही ढंग से नहीं चलता है। डीबगर मुख्य समारोह से बाहर निकलने के बाद बताता है:

हेप कॉरपोरेशन डिटेक्टेड:% एचएस ब्लॉक (# 55) 0x00034878 पर। सीआरटी ने पाया कि एप्लिकेशन ने हीप बफर के अंत में स्मृति को लिखा था।

तो मुझे लगता है कि कंपाइलर में "ऑटो" प्रकार की कटौती में बग हो सकता है। नीचे असेंबलर विंडो से पता चलता है कि, पहले "ऑपरेटर न्यू" कॉल में अनुरोधित ज्ञापन आकार 1 बाइट है, जबकि दूसरा "ऑपरेटर नया" 4 बाइट्स है। यह सुझाव देता है कि संकलक ने प्रयुक्त प्रकार के आकार पर एक बड़ी गलती की है।

क्या आपको लगता है कि यह एक कंपाइलर बग है? और क्या माइक्रोसॉफ्ट से कोई बग फिक्स है?

int main() 
{ 
004113C0 push  ebp 
004113C1 mov   ebp,esp 
004113C3 sub   esp,10Ch 
004113C9 push  ebx 
004113CA push  esi 
004113CB push  edi 
004113CC lea   edi,[ebp-10Ch] 
004113D2 mov   ecx,43h 
004113D7 mov   eax,0CCCCCCCCh 
004113DC rep stos dword ptr es:[edi] 
    const auto pa = new auto(banana); 
004113DE push  1 
004113E0 call  operator new (411181h) 
004113E5 add   esp,4 
004113E8 mov   dword ptr [ebp-104h],eax 
004113EE cmp   dword ptr [ebp-104h],0 
004113F5 je   main+51h (411411h) 
004113F7 mov   eax,dword ptr [ebp-104h] 
004113FD mov   dword ptr [eax],0C8h 
00411403 mov   ecx,dword ptr [ebp-104h] 
00411409 mov   dword ptr [ebp-10Ch],ecx 
0041140F jmp   main+5Bh (41141Bh) 
00411411 mov   dword ptr [ebp-10Ch],0 
0041141B mov   edx,dword ptr [ebp-10Ch] 
00411421 mov   dword ptr [pa],edx 
    const auto pb = new fruit_t(banana); 
00411424 push  4 
00411426 call  operator new (411181h) 
0041142B add   esp,4 
0041142E mov   dword ptr [ebp-0F8h],eax 
00411434 cmp   dword ptr [ebp-0F8h],0 
0041143B je   main+97h (411457h) 
0041143D mov   eax,dword ptr [ebp-0F8h] 
00411443 mov   dword ptr [eax],0C8h 
00411449 mov   ecx,dword ptr [ebp-0F8h] 
0041144F mov   dword ptr [ebp-10Ch],ecx 
00411455 jmp   main+0A1h (411461h) 
00411457 mov   dword ptr [ebp-10Ch],0 
00411461 mov   edx,dword ptr [ebp-10Ch] 
00411467 mov   dword ptr [pb],edx 
    static_assert(std::is_same<decltype(pa), decltype(pb)>::value, "not same!"); 
    delete pb; 
0041146A mov   eax,dword ptr [pb] 
0041146D mov   dword ptr [ebp-0ECh],eax 
00411473 mov   ecx,dword ptr [ebp-0ECh] 
00411479 push  ecx 
0041147A call  operator delete (411087h) 
0041147F add   esp,4 
    delete pa; 
00411482 mov   eax,dword ptr [pa] 
00411485 mov   dword ptr [ebp-0E0h],eax 
0041148B mov   ecx,dword ptr [ebp-0E0h] 
00411491 push  ecx 
00411492 call  operator delete (411087h) 
00411497 add   esp,4 
} 
+1

डीबगर में 'pa' का प्रकार क्या है? – RedX

+0

डीबगर शो: केला 0x000000c8 int; पी 0x000329d8 fruit_t * const; पीबी 0x00032a18 fruit_t * कॉन्स। बुरा, यह दिखाता है कि 'केले' प्रकार 'int' (नहीं 'fruit_t') है। जहां तक ​​मुझे पता है, वीसी 10 के डीबगर में कई बग हैं, इसलिए ऊपर प्रदर्शित प्रकार की जानकारी संदिग्ध है। – jgx

+0

घटनाक्रम मेरा डीबगर वीएस -2010 सही प्रकार (फल *) दिखाता है जो ऑटो के साथ आवंटित लोगों पर दुर्घटनाग्रस्त हो जाता है। – RedX

उत्तर

1

हाँ, मुझे लगता है कि यह एक वीएस -2010 बग है। XP SP3 (32-बिट) और VS2010 SP1 के साथ आपके (या कम से कम समान) के समान चल रहा है, मुझे एक ही त्रुटि मिलती है। यह enums के लिए विशिष्ट दिखता है, क्योंकि कक्षाओं के साथ कोशिश कर रहा है सब ठीक से काम कर दिखाया। मैंने 100000 के मूल्य के साथ enum में एक और फल वस्तु जोड़ने का भी प्रयास किया, यह सुनिश्चित करने के लिए कि यह आपके enum की तरह मूर्खतापूर्ण नहीं था 255 से नीचे सभी मान। समान परिणाम।

मैंने Microsoft Connect पर एक त्वरित खोज की, और मुझे इसके लिए एक बग रिपोर्ट नहीं दिखाई दे रही है, इसलिए मैं अनुशंसा करता हूं कि आप एक दर्ज करें। यह सुनिश्चित करने का सबसे अच्छा तरीका है कि माइक्रोसॉफ्ट जानता है और संभवतः इसे ठीक कर लेता है।

+1

यह बग VS2012 में तय किया गया था, फीडबैक रिपोर्ट दर्ज करने में कोई बात नहीं थी। –

+5

मैं तर्क दूंगा कि एक फीडबैक रिपोर्ट अभी भी दायर की जानी चाहिए। सबसे पहले, वीएस2012 अभी तक रिलीज़ नहीं है। सबसे महत्वपूर्ण बात यह है कि, अगर (जब) ​​इसे "ठीक नहीं करेगा" के रूप में बंद कर दिया गया है, तो कम से कम यह अन्य लोगों के लिए मिल जाएगा। –