Segmentation fault when malloc/free appear in loop in C -


मेरे पास ऐसे प्रोग्राम हैं जो मूल रूप से दिखता है:

  typedef struct cpl_def {int A; इंट बी; इंट ठीक; संरचना cpls * लिंक; } CPLS; Int मुख्य (शून्य) {int n1, n2; Int संख्या = 300; / * कहना * / int * a; ए = नल; Int * apt; Int * b; बी = नल; Int * bpt; सीपीएलएस * सीएलपीटीआर; Cplptr = NULL; Int i, j; (I = 0; i & lt; 2000; i ++) के लिए {if (i == 0) {cplptr = (cpls *) मॉलोक (num * sizeof (cpls)); / * संरचना का निर्माण / / (सीएलपीटीआर) initalize; } / * ... cplptr पर कार्रवाई ... * / FOO (cplptr); / * ... निर्धारित करें कि मुझे आकार n1 के एक सबसेट (आकार n1 का एक सकारात्मक पूर्णांक जो कि पाश के दौरान बदलता है) cplptr से प्रविष्टियों की आवश्यकता है ... * / n1 = FOO2 (cplptr); एन 2 = FOO3 (सीएलपीटीआर); / * ... cplptr में अतिरिक्त एन 2 प्रविष्टियों के लिए ए, बी के मूल्यों को बाहर निकालें ... * / cplptr2 = (cpls *) malloc (n2 * आकार (सीपीएलएस)); / * अतिरिक्त प्रविष्टियों को संग्रहित करने के लिए एक दूसरी संरचना * / / * .... cplptr2 पर कार्रवाई ... * / / * ... cplptr से n1 प्रविष्टियों की प्रतिलिपि को गतिशील रूप से आवंटित एरेज़ में ए, बी आकार के n1 में कॉपी करें ... * / A = मॉलोक (एन 1 * साइज़फ (इंट)); उपयुक्त = & amp; एक [0]; बी = मॉलोक (एन 1 * साइज़फ (इंट)); बीपीटी = & amp; बी [0]; के लिए (जे = 0; जम्मू & lt; num; j ++) {यदि (cplptr [j]। ओ == 1) {(* एपीटी ++) = cplptr [j] .a; (* Bpt ++) = cplptr [j] .b; }} मुक्त (cplptr); / * नि: शुल्क पहली संरचना * / cplptr = (सीपीएलएस *) मॉलोक ((एन 1 + एन 2) * आकारफ (सीपीएल)); / * पहले ढांचे के लिए आकार के n1 के एक सबसेट * / {cplptr [j] .a = a [* बी.आर. *] के लिए उचित आकार * / के लिए (जे = 0; जम्मू & lt; n1; j ++) / * प्रतिबिंबित करने के लिए पहली संरचना को पुन: j]; Cplptr [j]। बी = बी [जे]; Cplptr [j]। ओ = 1; } के लिए (जे = एन 1; जे एंड एलटी; एन 1 + एन 2; जे ++) / * चीजों को पहली संरचना में स्थानांतरित करें / / cplptr [j] .a = cplptr2 [j] .a; Cplptr [j] .b = cplptr2 [j] .b; Cplptr [j]। ओ = cplptr2 [j] ओके; } मुक्त (ए) मुफ़्त (बी) मुक्त (cplptr2); / * मुक्त दूसरी संरचना * /} / * अंत चलना i} / * अंत मुख्य () * /  

यह सिर्फ कंकाल का रूप है, लेकिन यह उम्मीद है कि एक तस्वीर पर्याप्त प्रदान करता है इस तरह यह आम तौर पर ठीक चलती है, लेकिन एन 1, एन 2 के कुछ मूल्यों के लिए, नि: शुल्क (सीपीएलपीटीआर) सेगमेंटेशन गलती का कारण लगता है इसे केवल एक बार कहा जाता है, और मैं cplptr के लिए malloc () कॉल करने के बाद और cplptr के लिए इसी मुफ़्त () से पहले पते की जांच करता हूं।

  .... cplptr = (cpls *) malloc ( संख्या * आकार (सीपीएल)); Printf ("इस% पी \ n", & amp; cplptr [0]) पर ठीक; ... प्रिंटफ़ ("इस% पी \ n", & amp; cplptr [0]) पर ठीक; मुक्त (cplptr) & lt; - विभाजन दोष यहाँ होता है  

पते से मेल खाते हैं, जिसका मतलब है कि मुफ्त () को मुक्त करना चाहिए, यह सही है? जीडीबी प्रोग्राम प्राप्त संकेत SIGSEGV, विभाजन गलती देता है 0xb7ce179b में ?? () /lib/tls/i686/cmov/libc.so.6 से और चरण वर्तमान फ़ंक्शन की सीमा नहीं मिल सकता है

क्या इस तरह से लागू करने के लिए एक और तरीका है कि विभाजन विफलता से बचा जाता है?

धन्यवाद आपके सुझावों के लिए एक लाख! किसी भी विचार पर क्या हो रहा है ??

यदि आप एक क्रैश मुक्त () पर मार रहे हैं, तो यह है ढेर भ्रष्टाचार की वजह से सबसे अधिक संभावना है - आप स्मृति के एक आवंटित ब्लॉक के अंत से परे लिख रहे हैं, एक सूचक को दो बार मुक्त करना, या समान।

लिनक्स पर इन प्रकार के मुद्दों को डिबग करने के लिए एक महान उपकरण है।


Comments

Popular posts from this blog

c++ - Linux and clipboard -

Visual Studio 2005: How to speed up builds when a VSMDI is open? -

booting ubuntu from usb using virtualbox -