Tip:
Highlight text to annotate it
X
>> डेविड मालन: सब ठीक है, वापस स्वागत है.
इस CS50 है.
इस सप्ताह सात की शुरुआत है.
तो यह एक समय हो गया है, इसलिए मुझे लगता है हमें लगा है जहां हम का एक बवंडर दौरे ले
दूर छोड़ दिया है और अब हम कहाँ जा रहे हैं.
>> तो यहाँ इस बात के लिए हो सकता पहली बार में कुछ गुस्से का कारण बना.
लेकिन उम्मीद है, आप शुरुआत कर रहे हैं यहाँ यह अर्थ क्या करने के लिए acclimate -
है जो एक सूचक का प्रतिनिधित्व सितारा अधिक आम आदमी की दृष्टि में, बस क्या?
तो यह एक पता है.
>> इसलिए इसके बारे में पता है स्मृति में कुछ.
और हम परतों वापस छील करने के लिए शुरू कर दिया कुछ हफ़्ते पहले, की तरह बातें
GetString और अन्य तरह के कार्यों यह सब समय लौट कर दिया गया है
जैसे स्मृति में चीजों के पते, में प्रथम चरित्र का पता
कुछ अनुक्रम.
>> इसलिए हम भी, वेलग्रिंड शुरू की जो आप इस समस्या के लिए उपयोग करने के लिए शुरू करेंगे
विशेष रूप से अगले के लिए, सेट समस्या के रूप में अच्छी तरह से सेट.
और वेलग्रिंड हमारे लिए क्या करता है?
यह स्मृति लीक के लिए जाँच करता है, और यह यह भी स्मृति के दुरुपयोग की जांच करता है.
>> यह कुछ संभावना के साथ, पता लगा सकता है अगर अपने कोड स्मृति को छूने जा रहा है
यह बस नहीं होना चाहिए.
इसलिए जरूरी नहीं कि एक दरार है, लेकिन आप अगर कुछ की सीमाओं से परे जाना
सरणी, और आप वास्तव में वेलग्रिंड चलाने और उस व्यवहार के लिए प्रेरित करते हुए
Valgrind है अपने प्रोग्राम में चल रहा है इसके अंदर चल रहा है, आप मिल जाएगा
इस तरह के संदेश - "अवैध लिखने की आकार 4, "जो, एक जोड़ी की याद
हफ्ते पहले मैं गलती से मतलब था कि जैसे एक int पर बहुत दूर
एक सरणी की सीमाओं से परे.
और इसलिए आकार 4 यहाँ आकार का मतलब उस विशेष int की.
>> तो वास्तव में आश्वासन ले कि Valgrind के उत्पादन, यह का प्रारूप,
बस नृशंस है.
यह गंदगी के माध्यम से देखने के लिए वास्तव में मुश्किल है रोचक जानकारी के लिए.
तो क्या हम यहाँ किया है सिर्फ अंश है अधिक की जोड़ी के कुछ
दिलचस्प लाइनों.
लेकिन एहसास है कि Valgrind के 80% उत्पादन एक का एक सा होने जा रहा है
व्याकुलता.
>> सिर्फ इस तरह के पैटर्न के लिए देखो - अवैध सही, अवैध पढ़ें, 40 बाइट्स
और ब्लॉकों में से कुछ संख्या निश्चित रूप से कर रहे हैं उस तरह खो दिया है, कीवर्ड्स.
और क्या आप उम्मीद देखेंगे कुछ है समारोह का पता लगाने की तरह
गलती अंदर वास्तव में है
यहां इस मामले में, किस लाइन में मेरे कोड जाहिरा तौर पर त्रुटि थी?
>> था जो memory.c नामक एक फाइल में 26 हम साथ खेल रहे थे उदाहरण
समय पर.
तो यह malloc में शायद नहीं है.
यह बजाय अपने कोड में शायद था.
तो हम फिर से इस देखेंगे और फिर लंबे समय से पहले.
>> तो scanf, यह एक में आया रूपों की जोड़ी इस प्रकार अब तक.
हम sscanf संक्षेप में देखा था.
यह की एक संख्या में कुछ था आप में में डुबकी लगाई अपनी
प्रश्नोत्तरी के लिए तैयारी.
और scanf वास्तव में क्या CS50 है पुस्तकालय के नीचे का उपयोग किया गया है
आदेश में कुछ समय के लिए हुड उपयोगकर्ता से इनपुट मिल.
>> उदाहरण के लिए, मैं CS50 खत्म करने के लिए कदम अगर यहां के उपकरण, मुझे खोल देना एक
उदाहरण आज scanf-0.c कहा जाता है कि और यह सुपर आसान है.
यह कोड की कुछ लाइनें है.
लेकिन यह कैसे getInt वास्तव दर्शाता इस समय के सभी काम कर रहा है.
>> यहां इस कार्यक्रम में रेखा 16 में , मैं एक पूर्णांक घोषित नोटिस.
तो कोई संकेत, कुछ भी नहीं जादुई वहाँ, बस एक पूर्णांक.
फिर 17 लाइन में, मैं का संकेत एक नंबर के लिए उपयोगकर्ता, कृपया.
तो फिर देर से 18 में, मैं यहाँ scanf का उपयोग करें.
और मुझे लगता है, की तरह printf की तरह, निर्दिष्ट मैं बोली की उम्मीद कर रहा हूँ कि
गंदें शब्द बोलना प्रतिशत मैं.
>> तो जाहिर प्रतिशत मैं,, एक पूर्णांक अर्थ.
लेकिन क्या दूसरा नोटिस scanf के लिए तर्क है.
कैसे आप दूसरे का वर्णन होगा अल्पविराम के बाद तर्क?
वह क्या है?
>> यह एक्स का पता है.
तो इस वजह से प्रदान करके उपयोगी है क्या करता है, एक्स के पते के साथ scanf
ऐसा करने के लिए समारोह में कहा कि है कि सशक्त?
बस वहाँ जाना है, लेकिन यह भी क्या नहीं?
>> यह करने के लिए एक बदलाव करें.
आप वहां जा सकते हैं, क्योंकि यह की तरह है स्मृति में एक स्थान के लिए एक मानचित्र की तरह.
और इतने लंबे समय आपको उपलब्ध कराने के रूप में scanf, या इस तरह के एक नक्शे, उस के साथ किसी भी समारोह
समारोह न केवल वहाँ जाना है, और कर सकते हैं मूल्य पर देखने के लिए, लेकिन यह भी कर सकते हैं
अगर उपयोगी है जो कि मूल्य, बदल scanf के जीवन में उद्देश्य के लिए है
विशेष रूप से, उपयोगकर्ता से इनपुट स्कैन कीबोर्ड से.
और एफ, जैसे स्वरूपित अर्थ printf, च एक स्वरूपित अर्थ
आप मुद्रित करना चाहते हैं कि स्ट्रिंग.
>> तो संक्षेप में, इस लाइन में 18 बस, कहते हैं उपयोगकर्ता से एक पूर्णांक को पढ़ने की कोशिश
कीबोर्ड और पर, एक्स के अंदर यह स्टोर जो कुछ भी पता एक्स में रहने के लिए होता है.
और फिर अंत में, 19 लाइन बस का कहना है, इस मामले में int के लिए धन्यवाद,.
>> तो मुझे आगे जाना है और इस बनाते हैं.
तो scanf 0 बनाते हैं.
मुझे आगे जाना है और जूम इन करते हैं
मैं जाने के लिए और के साथ इस भाग लेंगे डॉट्स scanf 0 स्लेश.
संख्या, कृपया?
50.
50 के लिए धन्यवाद.
तो यह काफी आसान है.
>> अब यह क्या कर रहा है?
यह एक पूरी गुच्छा नहीं कर रही है त्रुटि की जाँच.
उदाहरण के लिए, मैं सहयोग नहीं करते हैं, और मैं एक संख्या में टाइप करें, लेकिन नहीं है
बजाय मैं "हैलो" की तरह कुछ लिखने कि सिर्फ अजीब तरह का है.
चीजों की है और एक बहुत CS50 पुस्तकालय कुछ के लिए हमारे लिए कर दिया गया है
समय है कि reprompting है और reprompting.
>> फिर से प्रयास करें मुहावरा याद, cs50.c में था और उस में getInt कि कारण है
CS50 पुस्तकालय वास्तव में एक पूरी है लंबी लाइनों का गुच्छा, हम कर रहे हैं, क्योंकि
इस तरह बेवकूफ सामान के लिए जाँच.
उपयोगकर्ता नहीं दिया वास्तव में हमें, एक int?
वह या वह हमें कुछ दे दिया एक वर्णमाला पत्र की तरह?
यदि हां, हम पता लगाने के लिए चाहते हैं कि और उन पर चिल्लाना.
>> लेकिन चीजों को और अधिक दिलचस्प हो यह अगले उदाहरण में.
मैं scanf-1.c के लिए जाना है, एक क्या है मूलरूप में बदल गया है कि बात
यह अगले उदाहरण?
मैं, ज़ाहिर है, चार * उपयोग कर रहा हूँ बजाय int की.
>> तो यह दिलचस्प है, क्योंकि चार *, याद है, वास्तव में सिर्फ है
स्ट्रिंग के रूप में एक ही बात.
शायद यह एक सुपर है तो ऐसा लगता है GetString की सरल कार्यान्वयन.
लेकिन मैं परत वापस खुली दिया है CS50 पुस्तकालय की, तो मैं कर रहा हूँ
अब यह चार * बुला.
तो चलो जहां, अगर कहीं भी देखते हैं, हम गलत जाना.
>> 17 लाइन -
मैं फिर कहता हूँ, मुझे कुछ दे, इस मामले में, एक स्ट्रिंग.
और फिर अगली पंक्ति में, मैं scanf कॉल, फिर, यह एक स्वरूप कोड दे रही है,
लेकिन इस बार प्रतिशत है.
और फिर इस बार, मैं हूँ यह बफर दे रही है.
>> अब मैं का उपयोग नहीं कर रहा हूँ, नोटिस एम्परसेंड.
लेकिन यही कारण है कि यहां शायद ठीक है?
बफर पहले से ही क्या है वजह?
यह पहले से ही एक सूचक है.
यह पहले से ही एक पता है.
>> और चलो इस शब्द चलो मुझे "भ्रमित" चलो अभी के लिए, उदाहरण के लिए, यह कॉल
सादगी.
लेकिन मैं क्योंकि में यह बफर बुलाया है सामान्य, प्रोग्रामिंग में, यदि आपके पास एक
स्मृति, जो एक स्ट्रिंग सच का हिस्सा बस है, आप एक बफर यह फोन हो सकता है.
यह जानकारी स्टोर करने के लिए एक जगह है.
>> यूट्यूब की तरह बातें करने के लिए इसी तरह के जब वे, इतनी बात करने के बफरिंग रहे हैं कि
बस इसे से बिट्स डाउनलोड करने का मतलब इंटरनेट और एक में उन्हें भंडारण
स्थानीय सरणी, स्मृति की एक स्थानीय हिस्सा तो आप बिना बाद में यह देख सकते हैं कि
यह लंघन या फांसी पर आप वापस खेलते समय.
>> तो एक समस्या है, हालांकि यहाँ है मैं scanf बता रहा हूँ क्योंकि, उम्मीद है एक
उपयोगकर्ता से स्ट्रिंग.
यहां के पते है स्मृति का एक हिस्सा.
वहाँ कि स्ट्रिंग रखो.
क्यों है कि बाध्य दे हमें परेशानी है, हालांकि?
>> वह क्या है?
मैं का उपयोग करने की अनुमति दी हूँ स्मृति का वह हिस्सा?
तुम्हें पता है, मैं नहीं जानता.
बफर initialized किया गया है क्योंकि कुछ भी करने के लिए?
ऐसा नहीं है.
और इसलिए यह हम बुला रहा हूँ क्या है एक कचरा मूल्य, जो
एक औपचारिक शब्द नहीं है.
यह सिर्फ हमें पता नहीं है इसका मतलब क्या बिट्स कि चार बाइट्स के अंदर कर रहे हैं
मैं बफर के रूप में आवंटित किया है.
>> मैं malloc नहीं बुलाया है.
मैं निश्चित रूप से GetString नहीं बुलाया गया है.
तो जो वास्तव में है क्या जानता है बफर के अंदर?
और फिर भी scanf कह रही आँख बंद करके, वहाँ जाना और उपयोगकर्ता टाइप किया जो कुछ भी डाल दिया.
>> तो क्या कारण होने की संभावना है हमारे कोड में अगर हम इसे चलाने के?
शायद एक segfault.
शायद नहीं, लेकिन शायद एक segfault.
और मैं कहना शायद नहीं, क्योंकि कभी कभी आप कभी कभी, करते हैं
आप एक segfault नहीं मिलता.
कभी कभी तुम सिर्फ भाग्यशाली हो, लेकिन यह फिर भी होने जा रहा है
हमारे कार्यक्रम में एक बग.
>> तो मुझे आगे जाना है और इस संकलन करते हैं.
मैं इसे पुराने तरीके से करने के लिए जा रहा हूँ.
तो बजना पानी का छींटा 0, scanf -1, scanf-1.c, लिखें.
ओह, बहुत पुराना स्कूल.
चलो देखते हैं.
मैं कहाँ गए थे?
ओह, चार * बफर.
ओह, शुक्रिया -
ठीक है, बचाओ -
बहुत पुराने स्कूल.
ठीक है, यह एक समय हो गया है.
>> तो मैं बस फ़ाइल के बाद बचा लिया कि अस्थायी बना
एक पल पहले बदल जाते हैं.
और अब मैं इसे संकलित किया है मैन्युअल रूप बजना के साथ.
और अब मैं आगे जाने के लिए जा रहा हूँ और लिखें, scanf -1 चलाते हैं.
स्ट्रिंग कृपया.
मैं "नमस्ते." टाइप करेंगे
>> और अब, यहाँ कहाँ, सच में, printf है कर सकते हैं एक छोटे से परेशान है.
यह वास्तव में नहीं जा रहा है इस मामले में segfault.
Printf क्योंकि एक छोटी सी खास है यह इतना सुपर आमतौर पर इस्तेमाल किया है कि
अनिवार्य रूप से printf कर रही है हमें एक एहसान और साकार,
यह एक मान्य सूचक नहीं है.
मुझे सिर्फ प्रिंट करने के लिए खुद पर लेते हैं कोष्ठक में बाहर अशक्त, यहां तक कि
यह जरूरी है क्या नहीं है, हालांकि हम खुद को उम्मीद थी.
>> इसलिए हम वास्तव में आसानी से एक को प्रेरित नहीं कर सकता इस के साथ segfault, लेकिन स्पष्ट रूप से इस
मैं चाहता था व्यवहार नहीं है.
तो सरल समाधान क्या है?
खैर, scanf-2 में, मुझे का प्रस्ताव करते हैं कि बजाय वास्तव में सिर्फ एक आवंटन की
चार *, मेरे बारे में एक छोटे से होशियार रहने दो यह है, और मुझे बफर आवंटित करते हैं
16 अक्षरों का एक दृश्य के रूप में.
>> तो मैं तरीके के एक जोड़े में ऐसा कर सकते हैं.
मैं पूरी तरह से malloc इस्तेमाल कर सकते हैं.
लेकिन मैं सप्ताह में दो को वापस जा सकते हैं जब मैं सिर्फ एक पूरी गुच्छा की जरूरत
अक्षर.
वह सिर्फ एक सरणी है.
तो मुझे बजाय बफर को फिर से परिभाषित करते हैं 16 अक्षरों का एक सरणी.
>> और अब, मैं में बफर पारित जब -
और यह हम नहीं था कुछ है सप्ताह में दो के बारे में बात करते हैं -
लेकिन आप एक सरणी के रूप में इलाज कर सकते हैं यह एक पता है, हालांकि.
तकनीकी तौर पर, हमने देखा है, वे कर रहे हैं अलग एक छोटा सा.
आप इसे पारित लेकिन अगर scanf बुरा नहीं लगेगा किसी सरणी का नाम, क्योंकि क्या
हमें अनिवार्य रूप से है के लिए बजना क्या करेंगे जैसा कि सरणी के नाम का इलाज
16 बाइट्स का हिस्सा का पता.
>> तो यह बेहतर है.
यह अब है कि मुझे उम्मीद है कि सकता है इसका मतलब निम्नलिखित है.
मुझे एक पल के लिए बाहर ज़ूम करते हैं और scanf -2, ठीक संकलित कर सकता हूँ.
अब मुझे स्लैश scanf -2 मिला करते हैं.
स्ट्रिंग कृपया. "नमस्ते." और यह इस समय काम करने के लिए लग रहा था.
>> लेकिन किसी एक परिदृश्य प्रस्ताव कर सकते हैं यह अभी भी काम नहीं कर सकता जो में?
हाँ?
16 वर्णों से अधिक कुछ है.
और वास्तव में, हम हो सकता है एक छोटे से अधिक सटीक.
अब तो 15 अक्षर कुछ, वास्तव में हम ध्यान में रखने की जरूरत है क्योंकि
हम चाहते हैं कि बैकस्लैश शून्य की जरूरत है कि उलझाव स्ट्रिंग के अंत में,
एक तरफ scanf आम तौर पर जो होगा हमारे लिए ध्यान रखना.
>> तो मेरे जैसे कुछ करते हैं -
कभी कभी हम कर सकते हैं बस यह उस तरह छोड़ दें.
ठीक है, तो हम अब प्रेरित किया है हमारे विखंडन दोष.
क्यों?
मैं 15 से अधिक करने के लिए टाइप की वजह वर्ण, और इसलिए हम है वास्तव में
छुआ स्मृति कि मैं वास्तव में नहीं होना चाहिए.
>> तो क्या सच में यहाँ समाधान है?
ठीक है, हम एक लंबी स्ट्रिंग क्या जरूरत है?
ठीक है, हम शायद यह 32 बाइट्स बनाते हैं.
खैर, क्या है कि लंबे समय पर्याप्त नहीं है तो क्या होगा?
कैसे 64 बाइट्स के बारे में?
क्या है कि लंबे समय पर्याप्त नहीं है तो क्या होगा?
कैसे 128 या 200 बाइट्स के बारे में?
वास्तव में यहाँ समाधान क्या है सामान्य मामले, हम में पता नहीं है अगर
उपयोगकर्ता टाइप करने के लिए क्या हो रहा है अग्रिम?
>> यह गधा में बस की तरह एक बड़ा दर्द है, ईमानदार होना करने के लिए, जो है क्यों
CS50 पुस्तकालय कुछ दर्जन लाइनों की है सामूहिक रूप से लागू है कि कोड
हम नहीं करते कि एक तरह से स्ट्रिंग GetString अग्रिम में पता है क्या
उपयोगकर्ता टाइप करने के लिए जा रहा है.
विशेष रूप से, आप में वापस देखो दो सप्ताह पहले से cs50.c, आप देखेंगे
कि GetString वास्तव में करता है इस तरह से scanf का उपयोग नहीं.
दरअसल, यह एक चरित्र पढ़ता एक समय में.
>> क्योंकि एक के बारे में अच्छी बात यह है एक चरित्र पढ़ने में हम कर सकते है
हमेशा के लिए खुद की गारंटी कम से कम एक चार है.
मैं सिर्फ एक चार की घोषणा, और तब ले जा सकते हैं अभी तक ये वास्तव में बच्चे के कदम
एक में में एक चरित्र को पढ़ने कीबोर्ड से समय.
और फिर, क्या आप GetString देखेंगे है, यह से बाहर चलाता है हर समय है
कहते हैं, स्मृति के 16 बाइट्स, यह उपयोग करता है malloc, या एक चचेरा भाई उसके लिए
पुराने नकल, और अधिक स्मृति आवंटित रेंगने तो नई है, और में स्मृति
साथ एक समय में एक चरित्र हो रही है, और यह है कि से बाहर चलाता है
स्मृति का हिस्सा, पकड़ लेता है, इसे दूर फेंकता स्मृति का एक बड़ा हिस्सा, प्रतियां पुराने
नई, और दोहराता में.
और यह वास्तव में वास्तव में एक दर्द है के रूप में सरल कुछ को लागू
एक उपयोगकर्ता से इनपुट हो रही है.
>> तो आप scanf का उपयोग कर सकते हैं.
आप अन्य इसी तरह के कार्यों का उपयोग कर सकते हैं.
और ऑनलाइन पाठ्य पुस्तकों का एक बहुत उदाहरण करते हैं, लेकिन वे सभी कर रहे हैं
इस तरह की समस्याओं की चपेट में.
और अंत में, एक segfault हो रही एक तरह से परेशान है.
यह उपयोगकर्ता के लिए अच्छा नहीं है.
>> लेकिन सबसे खराब स्थिति में, क्या करता है यह मौलिक डाल अपने
के जोखिम में कोड?
संभावित हमले के कुछ प्रकार,.
हम के बारे में ऐसे ही एक हमले में बात की - ढेर बह निकला.
लेकिन सामान्य तौर पर, आप की अनुमति दी हो अगर हम किया था, एक बफर अतिप्रवाह एक
सिर्फ लिखने के साथ सप्ताह पहले की जोड़ी, जितना अधिक आप ढेर पर "नमस्ते" से
वास्तव में, संभावित, पर ले जा सकते हैं कंप्यूटर, या कम से कम डेटा पर मिलता है
आप का नहीं है.
>> हमारे पास तो यही कारण है संक्षेप में, यह है उन प्रशिक्षण पहियों.
लेकिन अब, हम उन्हें दूर ले शुरू हमारे कार्यक्रमों अब कोई ज़रूरत नहीं के रूप में,
जरूरी उपयोगकर्ता से इनपुट.
लेकिन समस्या के मामले में छह सेट, अपने इनपुट एक विशाल से आ जाएगा
150 से कुछ के साथ शब्दकोश फ़ाइल हजार अजीब शब्द.
>> तो आप के बारे में चिंता करने की ज़रूरत नहीं होगी उपयोगकर्ता का मनमाना इनपुट.
हम आपको कुछ मान्यताओं दे देंगे उस फ़ाइल के बारे में.
संकेत या scanf पर किसी भी सवाल या सामान्य में उपयोगकर्ता इनपुट?
>> ठीक है, तो एक पर तो एक त्वरित देखो दो सप्ताह पहले से विषय अनुगामी.
और कहा कि एक संरचना की इस धारणा थी.
ऐसा नहीं है कि - एक की इस धारणा संरचना, क्या जो था?
संरचना हमारे लिए क्या किया?
>> परिभाषित करें -
क्षमा करें?
एक चर प्रकार परिभाषित करें.
तो ऐसा.
हम वास्तव में दो विषयों के संयोजन कर रहे हैं.
तो typedef के साथ, याद हम कर सकते हैं कि एक तरह हमारी खुद की एक प्रकार है, की घोषणा
चार के लिए स्ट्रिंग * जैसे पर्याय,.
लेकिन typedef और संरचना का उपयोग कर, हम कर सकते हैं सही मायने में हमारे अपने डेटा संरचना बनाने.
>> उदाहरण के लिए, मैं जीएडिट में वापस जाना है यहां सिर्फ एक पल के लिए, और मुझे आगे जाना है
और कुछ करना पसंद है, मुझे बचाने के लिए इस रूप में, हम कहते हैं, structs.c
अस्थायी रूप से, मैं अभी जा रहा हूँ आगे बढ़ो और शामिल करने के लिए
standardio.h, int मुख्य शून्य.
और फिर यहाँ में, मैं चाहता हूँ कि लगता है एक प्रोग्राम लिखने के लिए भंडार है कि
कई से कई छात्रों घरों, उदाहरण के लिए.
तो यह एक registrarial की तरह है किसी प्रकार के डेटाबेस.
>> मैं नाम से एक छात्र की जरूरत है ताकि अगर, मैं चार * नाम की तरह कुछ कर सकता है,
और मैं ऐसा कुछ करता हूँ -
वास्तव में, के CS50 पुस्तकालय का उपयोग करते हैं इस एक बनाने के लिए बस एक पल के लिए
थोड़ा आसान है, तो हम उधार ले सकते हैं कोड की लाइनों की उन दर्जनों.
और चलो बस इसे सरल रखने के लिए.
हम स्ट्रिंग रखना होगा, और अब GetString.
>> इसलिए मुझे लगता है कि मैं नाम संग्रहीत किया है कि अब दावा कुछ छात्र, और के घर की
कुछ छात्र, बस चर का उपयोग जैसे हमने किया और एक सप्ताह में.
लेकिन मैं अब का समर्थन करना चाहते हैं कई छात्रों को.
ठीक है, तो अपनी प्रवृत्ति ऐसा करने के लिए कर रहे हैं स्ट्रिंग NAME2, GetString, स्ट्रिंग हो जाता है
house2 GetString हो जाता है.
और फिर हमारे तीसरे छात्र, के name3 GetString करते हैं.
>> ठीक है, तो यह उम्मीद है कि हड़ताली है आप के रूप में बेवकूफ की तरह,
इस प्रक्रिया को वास्तव में कभी नहीं है क्योंकि अंत करने के लिए जा रहा है, और यह सिर्फ जा रहा है
मेरे कोड देख भी बदतर बना और बदतर और बदतर.
लेकिन हम दो सप्ताह में भी इस का हल.
हमारे अपेक्षाकृत स्वच्छ समाधान क्या था हम में से कई चर था जब
सभी संबंधित हैं, लेकिन कर रहे हैं कि एक ही डेटा प्रकार हम इस नृशंस गड़बड़ नहीं करना चाहता था
की इसी चर नाम दिया?
हम बजाय क्या किया?
>> इसलिए मुझे लगता है मैं कुछ स्थानों के बारे में सुना लगता है.
हम एक सरणी था.
आप के कई उदाहरण चाहते हैं कुछ, क्यों हम यह सब साफ नहीं है
ऊपर और बस का कहना है, मुझे दे सरणी के नाम कहा जाता है?
>> और अब के लिए, की हार्ड कोड 3 चलो.
और फिर मुझे एक और सरणी दे घरों कहा जाता है, और के लिए मुझे दो
अब मुश्किल कोड 3.
और मैं उसे बड़े पैमाने पर साफ कर दिया है मैं अभी बनाया है कि गंदगी.
अब, मैं अभी भी कड़ी मेहनत 3 कोडित है, लेकिन और भी 3 गतिशील रूप से आ सकता है
उपयोगकर्ता, या argv, या पसंद है.
तो यह पहले से ही क्लीनर है.
>> लेकिन क्या इस बारे में परेशान है है कि अब, एक नाम किसी न किसी तरह है, भले ही
मूलरूप से जुड़ा हुआ एक छात्र के घर -
यह है कि मैं वास्तव में एक छात्र है का प्रतिनिधित्व करना चाहते हैं -
मैं अब समानांतर हैं कि दो सरणियों है वे कर रहे हैं कि समझ में
एक ही आकार, और नाम ब्रैकेट 0 शायद, घरों ब्रैकेट 0 नक्शे
और नाम 1 नक्शे कोष्ठक घरों के लिए 1 ब्रैकेट.
दूसरे शब्दों में, कि छात्र में रहती है उस घर, और कहा कि अन्य छात्र
कि दूसरे घर में रहती है.
लेकिन निश्चित रूप से यह हो सकता है और भी अधिक सफाई से किया.
>> खैर, यह वास्तव में, यह कर सकते हैं.
और मुझे आगे जाना है और खुला structs.h ऊपर, और तुम हूँ
यहाँ इस विचार को देखें.
मैं आप के रूप में, typedef का उपयोग किया है कि नोटिस घोषणा करने के लिए एक पल पहले तक alluded हमारे
खुद के डेटा प्रकार.
लेकिन मैं भी इस दूसरे कीवर्ड का उपयोग कर रहा हूँ मुझे एक नया देता है जो बुलाया संरचना
डेटा संरचना.
>> और मैं दावा यह आंकड़ा संरचना जा रहा है के अंदर दो बातों के लिए
यह - नाम नामक एक स्ट्रिंग, और एक स्ट्रिंग घर बुलाया.
और नाम मैं करने के लिए देने के लिए जा रहा हूँ इस डेटा संरचना जा रहा है
छात्र बुलाया जाए.
मैं मैं चाहता हूँ कुछ भी कह सकते हैं, लेकिन इस शब्दार्थ बनाने
मेरे मन में मेरे लिए कोई मतलब.
>> तो अब, मैं एक बेहतर संस्करण को खोलने अगर कार्यक्रम की मैं लिखना शुरू कर दिया
वहाँ, मुझे शीर्ष पर स्क्रॉल करते हैं.
और कोड के कुछ और लाइनें है यहाँ, लेकिन मेरे लिए ध्यान केंद्रित
एक पर पल.
मैं छात्रों को बुलाया एक निरंतर घोषित कर दिया है और कठिन अब के लिए 3 कोडित.
लेकिन अब, नोटिस कैसे साफ मेरे कोड प्राप्त करने के लिए शुरू होता है.
>> लाइन 22 में, मैं घोषणा छात्रों की सरणी.
और कहा कि छात्र जाहिरा तौर पर है नोटिस अब एक डेटा प्रकार.
इस वजह से फाइल, नोटिस के शीर्ष पर मुझे लगता है कि हैडर फ़ाइल शामिल किया है
मैं बस एक पल पहले तक खींच लिया है.
और कहा कि शीर्ष फाइल काफी बस था एक छात्र की इस परिभाषा.
>> तो अब, मैं अपने स्वयं के कस्टम डेटा बनाया है टाइप सी कि साल के लेखकों
पहले अग्रिम में नहीं सोचा.
लेकिन कोई बात नहीं.
मैं इसे अपने आप कर सकते हैं.
तो यह छात्रों को बुलाया एक सरणी है जिसका सदस्यों में से प्रत्येक
एक छात्र संरचना है.
और मैं चाहता हूँ कि उन में से तीन सरणी में.
>> और अब, क्या बाकी है इस कार्यक्रम की क्या ज़रूरत है?
मैं एक छोटे से मनमाने ढंग से कुछ की जरूरत है.
तो, आगे 24 ऑनलाइन से मैं 0-3 पुनरावृति.
मैं तो के लिए उपयोगकर्ता पूछना छात्र का नाम.
और फिर मैं पहले की तरह GetString का उपयोग करें.
तब मैं छात्र के घर के लिए पूछना, और मैं पहले की तरह GetString का उपयोग करें.
>> लेकिन सूचना - थोड़ा नया वाक्यविन्यास का टुकड़ा -
मैं, मैं वें छात्र को अभी भी सूचकांक कर सकते हैं लेकिन कैसे मैं विशिष्ट डेटा पर मिलता है
संरचना के अंदर क्षेत्र?
खैर, जाहिरा तौर पर क्या है वाक्यविन्यास का नया टुकड़ा?
यह सिर्फ डॉट ऑपरेटर है.
>> हम वास्तव में इस से पहले नहीं देखा है.
आप आपने अगर pset पांच में यह देखा है बिटमैप फ़ाइलों के साथ पहले से ही में डुबकी लगाई.
लेकिन डॉट सिर्फ इस के अंदर का मतलब संरचना या कई क्षेत्रों, डॉट दे
नाम, या मुझे डॉट घर दे.
उस संरचना के अंदर जाने का मतलब और विशेष रूप से उन क्षेत्रों को मिलता है.
>> इस कार्यक्रम के बाकी क्या करता है?
यह सब है कि सेक्सी नहीं है.
मैं फिर से 0-3 पुनरावृति सूचना है कि, और मैं बस एक अंग्रेजी बना
इतना और इतनी तरह मुहावरा ऐसे और में है ऐसे घर से डॉट नाम में गुजर
i-वीं के छात्र और उनके घर के रूप में अच्छी तरह से.
>> और फिर अंत में, अब हम पाने के लिए शुरू करेंगे इस बारे में गुदा, अब हम कर रहे हैं कि
क्या malloc से परिचित और अन्य कार्यों के लिए किया गया है
यह सब समय कर रहे हैं.
क्यों मैं नाम दोनों को मुक्त करने की क्या ज़रूरत है और घर, भले ही मैं
malloc फोन नहीं किया?
>> GetString किया.
और उसके लिए गंदे छोटे से रहस्य था कई हफ्तों, लेकिन GetString है
सब से अधिक स्मृति लीक किया गया इस प्रकार अब तक सभी सेमेस्टर जगह है.
और valgrand अंत में होगा हमारे लिए यह प्रकट करते हैं.
>> क्योंकि मुझे पता है लेकिन यह एक बड़ा सौदा नहीं है मैं बस नाम मुक्त कर सकते हैं
और घर, तकनीकी, हालांकि सुपर, सुपर सुरक्षित, मैं होना चाहिए
यहाँ की जाँच के कुछ त्रुटि रही.
आप कह रही है अपने सहज ज्ञान क्या हैं?
मैं के लिए क्या जाँच की जानी चाहिए मैं एक है क्या मुक्त करने से पहले
स्ट्रिंग, उर्फ जो एक चार *?
>> छात्रों अगर मैं वास्तव में जाँच की जानी चाहिए ब्रैकेट मैं नाम नहीं करता है डॉट
बराबर अशक्त.
तो यह आगे जाने के लिए ठीक है और मुक्त हो जाएगा कि सूचक, और उसी या अन्य
एक के रूप में अच्छी तरह से.
छात्रों मैं डॉट कोष्ठक तो घर नहीं है अशक्त करने के लिए बराबर है, यह अब रक्षा करेगा
कोने मामले के खिलाफ जो में GetString बातिल की तरह कुछ देता है.
और हम एक क्षण पहले, printf इच्छा देखा बस कह कर हमें यहाँ ऊपर की रक्षा
अशक्त, अजीब लग रहा है, जो.
लेकिन कम से कम यह segfault नहीं होगा, हमने देखा है.
>> खैर, मुझे यहां एक और बात करते हैं. structs -0 एक बेवकूफ कार्यक्रम की तरह है
मैं तो यह सभी डेटा दर्ज करें, और क्योंकि कार्यक्रम समाप्त होता है एक बार वह खो दिया है.
लेकिन मुझे आगे जाना है और यह करते हैं.
मुझे टर्मिनल बनाने दो. एक बड़ा सा खिड़की.
मुझे बनाते हैं structs -1, जो इस का एक नया संस्करण है.
>> मैं एक छोटा सा में ज़ूम करेंगे.
और अब मुझे डॉट चलाते हैं स्लैश structs-1.
छात्र का नाम -
डेविड माथर, रोब किर्कलैंड करते हैं के लॉरेन Leverett करते हैं.
क्या अब दिलचस्प की सूचना है -
और मैं केवल इस वजह से जानते हैं मैं प्रोग्राम लिखा -
एक फाइल मेरे वर्तमान पर अब वहाँ निर्देशिका students.csv कहा जाता है.
आप में से कुछ देखा हो सकता है इन वास्तविक दुनिया में.
>> एक सीएसवी फ़ाइल क्या है?
अल्पविराम से अलग किए गए मान.
यह तरह की तरह है एक गरीब आदमी का एक एक्सेल फ़ाइल का संस्करण.
यह पंक्तियों और स्तंभों की एक मेज है कि आप, एक्सेल की तरह एक कार्यक्रम में खोल सकते हैं
या एक मैक पर संख्या.
>> और मैं जीएडिट पर यहाँ इस फाइल को खोलते हैं, सूचना - और संख्या वहाँ नहीं कर रहे हैं.
वह सिर्फ जीएडिट कह रही है मुझे नंबर लाइन.
इस की पहली पंक्ति पर नोटिस फ़ाइल दाऊद और माथर है.
अगली पंक्ति रोब अल्पविराम किर्कलैंड है.
और तीसरी पंक्ति लॉरेन है अल्पविराम Leverett.
>> तो मैं क्या बनाया है?
मैं अब एक सी प्रोग्राम लिखा है कि प्रभावी ढंग से स्प्रेडशीट उत्पन्न कर सकते हैं
कि एक में खोला जा सकता है एक्सेल जैसे कार्यक्रम.
बिल्कुल नहीं है कि सम्मोहक एक डेटा सेट, लेकिन आप में से बहुत बड़ा हिस्सा है अगर
आप वास्तव में चाहते हैं कि डेटा हेरफेर और का ग्राफ बनाने और
जैसे, यह शायद एक है उस डेटा को बनाने के लिए जिस तरह से.
इसके अलावा, CSVs वास्तव में सुपर आम हैं सिर्फ साधारण डेटा संग्रहीत करने के लिए -
याहू वित्त, उदाहरण के लिए, यदि आप प्राप्त उनके तथाकथित के माध्यम से शेयरों के भाव
एपीआई, आप की सुविधा देता है कि नि: शुल्क सेवा वर्तमान अप करने की तारीख शेयर मिल
वे, कंपनियों के लिए उद्धरण में डेटा वापस दे
सुपर सरल सीएसवी प्रारूप.
>> तो हम ऐसा कैसे कर दिया?
खैर, इस कार्यक्रम के सबसे नोटिस लगभग एक ही.
बल्कि प्रिंट से, यहां नीचे नोटिस बाहर, लाइन 35 पर छात्र
आगे, मैं मैं बचत कर रहा हूँ कि दावा डिस्क के लिए छात्रों को, तो एक फ़ाइल बचत.
>> इसलिए मैं * एक फाइल घोषणा कर रहा हूँ नोटिस -
अब, यह सी में एक विसंगति की तरह है जो भी कारण के लिए, फ़ाइल सभी टोपी है,
सबसे अन्य डेटा प्रकार की तरह नहीं है जो सी. में लेकिन यह एक निर्मित है
डेटा प्रकार, फ़ाइल *.
और मैं एक फ़ाइल के लिए एक संकेत घोषणा कर रहा हूँ, तुम उस के बारे में सोच सकते हैं.
>> fopen फ़ाइल खोलने का मतलब है.
आप को खोलने के लिए क्या फ़ाइल चाहते हो?
मैं मैं है कि एक फ़ाइल को खोलने के लिए चाहते हैं मनमाने ढंग से students.csv कहते हैं.
मैं चाहता हूँ कि कुछ भी कह सकते हैं.
>> और फिर एक अनुमान ले.
दूसरा तर्क क्या करता है शायद fopen के लिए क्या मतलब है?
ठीक है, डब्ल्यू लिखने के लिए, कर सकता है पढ़ने के लिए हो आर.
आप अगर एक संलग्न के लिए नहीं है पंक्तियों और नहीं जोड़ना चाहते हैं
पूरी बात को अधिलेखित.
>> लेकिन मैं सिर्फ यह फाइल नहीं बनाना चाहता एक बार, तो मैं बोली डब्ल्यू गंदें शब्द बोलना इस्तेमाल करेंगे.
और मुझे पता है कि केवल पढने से प्रलेखन, या आदमी पेज.
फ़ाइल रिक्त नहीं है - दूसरे शब्दों में, वहाँ कुछ भी नहीं गलत हो गया है -
मुझे अधिक पुनरावृति करते हैं 0-3 छात्रों को.
>> और अब वहाँ कुछ नोटिस कभी तो थोड़ा अलग
यहाँ लाइन 41 के बारे में.
यह printf नहीं है.
यह फाइल printf के लिए fprintf है.
तो यह फ़ाइल में लिखने के लिए जा रहा है.
कौन सा फाइल?
जिसका सूचक आपके द्वारा निर्दिष्ट एक पहले तर्क के रूप में.
>> तो फिर हम एक प्रारूप स्ट्रिंग निर्दिष्ट करें.
तब हम हम क्या चाहते हैं स्ट्रिंग निर्दिष्ट पहला प्रतिशत के लिए में प्लग, और
फिर एक और चर या दूसरी प्रतिशत है.
तो फिर हम fclose साथ फ़ाइल बंद करें.
मैं हालांकि, पहले के रूप में स्मृति से मुक्त मैं में वापस जाने के लिए और जोड़ने चाहिए
अशक्त के लिए कुछ चेक.
>> और यह बात है.
fopen, fprintf, fclose मुझे देता है पाठ फ़ाइलें बनाने की क्षमता.
अब, आप समस्या से पांच सेट में देखेंगे छवियों शामिल है, जो आप का उपयोग होगा
बाइनरी फ़ाइलों के बजाय.
लेकिन मूलरूप में, विचार, एक ही है भले ही आप हूँ कार्यों
देखना थोड़ा अलग हैं.
>> तो बवंडर दौरे, लेकिन आप मिल जाएगा सब भी फाइल के साथ परिचित I/O--
इनपुट और आउटपुट - pset पाँच के साथ.
और के बारे में किसी भी सवाल यहां प्रारंभिक मूल बातें?
हाँ?
>> क्या आप एक नल मान को मुक्त करने की कोशिश की तो?
मुक्त हो गया है जब तक कि मेरा मानना है कि एक उपयोगकर्ता के अनुकूल है, आप कर सकते हैं थोड़ा अधिक
संभावित segfault.
मैं नहीं है क्योंकि यह शून्य पासिंग बुरा है आप के लिए जाँच करने के लिए स्वतंत्र परेशान मानना है,
यह संभवतः एक बेकार हो जाएगा क्योंकि इसके लिए ही करने के लिए समय की
दुनिया में हर कोई.
अच्छा सवाल है, यद्यपि.
>> ठीक है, तो इस तरह का हो जाता है एक दिलचस्प विषय के लिए हमें.
समस्या के विषय सेट पांच फोरेंसिक है.
कम से कम उस एक भाग है समस्या का सेट.
फोरेंसिक आम तौर पर करने के लिए संदर्भित करता है कि हो सकता है या जानकारी की वसूली
हटा दिया गया है नहीं हो सकता जानबूझ.
और इसलिए मुझे लगता है मैं तुम्हें एक त्वरित देने लगा वास्तव में सब क्या हो रहा है का स्वाद
नीचे इस समय आपके कंप्यूटर के हुड.
>> उदाहरण के लिए, आप के अंदर है तो अपने लैपटॉप या अपने डेस्कटॉप कंप्यूटर एक
हार्ड ड्राइव, यह या तो एक यांत्रिक है वास्तव में spins कि डिवाइस -
थाली बुलाया परिपत्र चीज़ें हैं कि काफी क्या मैं की तरह दिखते
अभी हालांकि, यहां स्क्रीन पर पड़ा इस तेजी से पुराने स्कूल है.
यह एक तीन और एक से डेढ़ इंच है हार्ड ड्राइव.
और साढ़े तीन इंच के लिए संदर्भित करता है बात के साथ आप इसे स्थापित जब
एक कंप्यूटर में.
>> अब आपके लैपटॉप में आप लोगों में से कई सॉलिड स्टेट ड्राइव, या SSDs है,
नहीं चलती भागों है.
वे और अधिक रैम की तरह और कम पसंद कर रहे हैं इन यांत्रिक उपकरणों.
लेकिन विचारों में अभी भी वही कर रहे हैं, निश्चित रूप से वे संबंधित हैं
समस्या को पांच सेट.
>> और तुम अब एक हार्ड ड्राइव के बारे में अगर आपको लगता है एक चक्र, किया जा रहा है जो प्रतिनिधित्व करता है
मैं यहाँ इस तरह आकर्षित करेंगे.
आप अपने कंप्यूटर पर एक फ़ाइल बनाते हैं, यह एक SSD है, या में चाहे
इस मामले में, एक पुराने स्कूल हार्ड ड्राइव, उस फाइल कई बिट्स शामिल हैं.
चलो यह इस 0 और 1 है कि हम कहते हैं, 0 और 1 की एक पूरी गुच्छा.
तो यह अपने पूरे हार्ड ड्राइव है.
यह जाहिरा तौर पर एक बहुत बड़ा फ़ाइल है.
और यह उस पर 0 और 1 का उपयोग कर रहा है शारीरिक थाली का भाग.
>> खैर, कि शारीरिक भाग क्या है?
खैर, यह पता चला है कि एक हार्ड ड्राइव पर, इस प्रकार के कम से कम, वहाँ है
इन छोटे छोटे चुंबकीय कणों.
और वे अनिवार्य रूप से उत्तर दिया है और उन्हें दक्षिण डंडे, इतना है कि आप अगर
उन चुंबकीय कणों में से एक बारी इस तरह, आप यह कह सकते हैं कि
एक 1 का प्रतिनिधित्व.
और यह करने के लिए दक्षिण उल्टा है अगर उत्तरी, आप यह कह सकते हैं कि
एक 0 का प्रतिनिधित्व.
>> तो वास्तविक भौतिक दुनिया में, कि आप में कुछ का प्रतिनिधित्व कर सकता कैसे
बाइनरी 0 से राज्य और एक 1.
ताकि सभी एक फाइल है.
चुंबकीय की एक पूरी गुच्छा है उनके इस तरह से कर रहे हैं या कि कणों
इस तरह, बनाने पैटर्न 0 और 1 की.
>> आप एक फ़ाइल को बचाने लेकिन जब यह पता चला है, कुछ जानकारी अलग से बचाया है.
तो यह एक छोटी मेज है, इतनी बात करने के लिए एक निर्देशिका,.
और मैं इस स्तंभ नाम फोन, और हूँ मैं इस कॉलम स्थान बुलाता हूँ.
>> और मुझे लगता है, कहने जा रहा हूँ यह मेरा फिर से शुरू है.
मेरा resume.doc में संग्रहीत किया जाता है स्थान, 123 कहते हैं.
मैं हमेशा उस संख्या के लिए जाना.
लेकिन जैसे कि कहने के लिए पर्याप्त राम में, आप एक हार्ड ड्राइव ले जा सकते हैं
कि एक गीगाबाइट या 200 गीगाबाइट है या एक टेराबाइट, और आप कर सकते हैं
बाइट्स के सभी संख्या.
आप 8 बिट के सभी हिस्सा नंबर कर सकते हैं.
>> तो हम कह देंगे कि इस स्थान 123 है.
मेरे परिचालन के अंदर तो इस निर्देशिका प्रणाली याद है मेरी
फिर से शुरू स्थान 123 पर है.
लेकिन यह दिलचस्प हो जाता है जब आप एक फ़ाइल को नष्ट.
>> उदाहरण के लिए तो -
और शुक्र है, दुनिया की सबसे अधिक है इस पर पकड़ा - क्या होता है जब
आप अपने मैक ओएस कचरा पेटी में एक फ़ाइल खींचें या अपने Windows रीसायकल बिन?
कि ऐसा करने का उद्देश्य क्या है?
यह फाइल से छुटकारा पाने के लिए स्पष्ट रूप से है, लेकिन क्या खींचकर का कार्य करता है और
अपने ट्रैश या में छोड़ने अपने रीसायकल बिन एक कंप्यूटर पर करते हैं?
>> बिल्कुल कुछ भी नहीं, वास्तव में.
यह सिर्फ एक फ़ोल्डर की तरह है.
यह सुनिश्चित किया जाना, एक विशेष फ़ोल्डर है.
लेकिन यह वास्तव में फ़ाइल को नष्ट करता है?
>> ठीक है, नहीं, क्योंकि आप में से कुछ शायद लानत ओह, तुम नहीं किया, की तरह किया गया है
ऐसा करने के लिए मतलब है.
तो अगर आप डबल क्लिक करें कचरा पेटी या रीसायकल बिन.
आप आसपास poked है और तुम बरामद किया बस इसे खींचकर फ़ाइल
वहाँ से बाहर.
तो जाहिर है, यह जरूरी नहीं है इसे हटाने.
>> ठीक है, तुम कि अधिक चालाक हो.
तुम्हें पता है कि बस में खींच कचरा या रीसायकल बिन मतलब यह नहीं है
आप कचरा खाली कर रहे हैं.
तो आप मेनू के लिए ऊपर जाना है, और तुम कहते हो रद्दी खाली या खाली रीसायकल बिन.
फिर क्या होता है?
>> हाँ, तो यह और अधिक इसलिए हटा दिया गया है.
लेकिन ऐसा होता है कि यह सब है.
कंप्यूटर जहाँ भूल जाता है resume.doc था.
>> लेकिन क्या जाहिरा तौर पर नहीं बदला है तस्वीर में?
बिट्स, मैं दावा है कि 0 और 1 हैं कुछ शारीरिक पहलू से की साइट पर
हार्डवेयर.
वे वहाँ अभी भी कर रहे हैं.
यह सिर्फ कंप्यूटर की गई है वे क्या कर रहे हैं भूल.
>> इसलिए यह अनिवार्य रूप से मुक्त कर दिया है फ़ाइल की बिट्स वे पुन: उपयोग किया जा सकता है.
लेकिन यदि आप अधिक फाइलें नहीं बना जब तक और अधिक फाइलें, और अधिक फाइलें होगा
संभवतया, उन 0 और 1, उन चुंबकीय कणों, पुन: उपयोग किया हो,
के लिए ऊपर या दाएं ऊपर अन्य फाइलें, 0 और 1.
>> तो तुम समय की इस खिड़की है.
और यह उम्मीद के मुताबिक की नहीं है लंबाई, वास्तव में.
यह आपके हार्ड के आकार पर निर्भर करता है ड्राइव और कितने फ़ाइलें आप की है और
कितनी जल्दी आप नए बनाते हैं.
लेकिन समय की इस विंडो के दौरान वहाँ उस फ़ाइल को पूरी तरह से अभी भी है जो
वसूली.
>> तो तुम कभी McAfee जैसे कार्यक्रमों का उपयोग करते हैं या Norton ठीक करने के लिए प्रयास करने के लिए
डेटा, वे सब कर रहे हैं करने के लिए कोशिश कर रहा है करने के लिए इस तथाकथित निर्देशिका की वसूली
आपकी फ़ाइल था जहां यह पता लगाने.
और कभी कभी Norton और कहेंगे, फाइल 93% वसूली योग्य है.
खैर, इसका क्या मतलब है?
वह सिर्फ मतलब है कि कुछ अन्य फ़ाइल संयोग से, कहते हैं, का उपयोग कर समाप्त
अपने मूल फाइल से बाहर उन बिट्स.
>> तो शामिल वास्तव में क्या है डाटा की वसूली में?
खैर, आप की तरह कुछ भी नहीं है अगर नॉर्टन आपके कंप्यूटर पर पहले से स्थापित,
आप कभी कभी ऐसा कर सकते हैं सर्वोत्तम है की तलाश में पूरे हार्ड ड्राइव पर
बिट्स के पैटर्न.
और समस्या के विषयों में से एक सेट पाँच आप खोज करेंगे कि है
एक हार्ड ड्राइव के बराबर, एक फोरेंसिक एक से एक कॉम्पैक्ट फ़्लैश कार्ड की छवि
डिजिटल कैमरा, 0s के लिए खोज और कहा कि आम तौर पर, साथ 1s उच्च
संभावना का प्रतिनिधित्व एक JPEG छवि के लगते हैं.
>> और तुम लोगों ने उन छवियों को ठीक कर सकते हैं मैं इस पैटर्न के देखते हैं, यह सोचते हैं
साथ फोरेंसिक छवि, पर बिट्स प्रबल संभावना है कि, निशान
एक JPEG के शुरू.
और मैं फिर से एक ही पैटर्न देखते हैं, कि शायद की शुरुआत के निशान
एक और जेपीईजी, और अन्य जेपीईजी, और एक और जेपीईजी.
और यह आमतौर पर है कि कैसे डेटा वसूली काम करेंगे.
क्या JPEGs के बारे में अच्छी बात है, भले ही है फ़ाइल स्वरूप ही कुछ हद तक है
जटिल, हर तरह के की शुरुआत फ़ाइल वास्तव में काफी पहचान योग्य है
और जैसा कि आप देखेंगे, सरल, यदि आपने ऐसा नहीं किया है.
>> तो चलो एक करीब देखो नीचे ले जाने हो गया है कि क्या वास्तव में के रूप में डाकू
चल रहा है, और क्या इन 0 और 1 आप एक के लिए थोड़ा और अधिक देने के लिए कर रहे हैं,
इस विशेष चुनौती के लिए संदर्भ.
>> [वीडियो प्लेबैक]
>> कहाँ अपने पीसी भंडार सबसे इसके स्थायी डेटा की.
ऐसा करने के लिए, डेटा रैम से यात्रा बता कि सॉफ्टवेयर संकेतों के साथ
मुश्किल यह है कि डेटा स्टोर करने के लिए कैसे ड्राइव.
हार्ड ड्राइव सर्किट अनुवाद वोल्टेज में उन संकेतों
उतार चढ़ाव.
इन, बारी में, हार्ड ड्राइव के नियंत्रण चलती भागों, कुछ का कुछ
में छोड़ा चलती भागों आधुनिक कंप्यूटर.
>> संकेतों में से कुछ एक मोटर नियंत्रण जो धातु में लिपटे थाली घूमती है.
आपका डेटा वास्तव में संग्रहीत किया जाता है इन थाली पर.
अन्य संकेतों को पढ़ने / लिखने के लिए कदम पढ़ने के लिए सिर या
थाली पर डेटा लिखें.
इतनी सटीक यह मशीनरी कि एक मानव बाल भी बीच पारित नहीं कर सकता
सिर और कताई थाली.
फिर भी, यह सब भयानक गति से काम करता है.
>> [अंत वीडियो प्लेबैक]
>> डेविड मालन: एक छोटी सी में ज़ूम अब क्या है पर गहरा
वास्तव में उन थाली पर.
>> [वीडियो प्लेबैक]
>> चलो क्या हम बस पर देखने दो. धीमी गति में देखा था.
बिजली का एक संक्षिप्त नाड़ी है जब flips, तो पढ़ने / लिखने के सिर को भेजा
के लिए एक छोटे से विद्युत पर एक दूसरे के एक अंश.
चुंबक, एक क्षेत्र है जो बनाता है एक छोटे, छोटे के polarity परिवर्तन
धातु के कणों का भाग है जो कोट प्रत्येक थाली सतह.
>> इन छोटे का एक पैटर्न श्रृंखला, डिस्क पर आरोप लगाया अप क्षेत्रों
की एक एकल बिट का प्रतिनिधित्व करता है बाइनरी संख्या में डेटा
कंप्यूटर द्वारा उपयोग किया प्रणाली.
अब, वर्तमान एक तरह से भेजा जाता है तो पढ़ने / लिखने के सिर के माध्यम से, क्षेत्र
एक दिशा में polarized है.
वर्तमान में भेजा जाता है तो विपरीत दिशा,
ध्रुवीकरण उलट है.
>> आप हार्ड डिस्क से डाटा प्राप्त करें कैसे?
बस प्रक्रिया को उल्टा.
तो यह डिस्क पर कणों है उस में चालू हो
/ लिखने के सिर घूम पढ़ा.
इनमें से लाखों लोगों को एक साथ रखा चुम्बकीय क्षेत्रों, और
आप एक फाइल मिल गया है.
>> अब, एक एकल फाइल के टुकड़े हो सकता है सभी एक ड्राइव के पर बिखरे हुए किया
तरह की गड़बड़ की तरह थाली, अपनी मेज पर पत्रों का.
तो एक विशेष अतिरिक्त फ़ाइल ट्रैक रखता है सब कुछ है, जहां की.
आप आप था इच्छा मत करो ऐसा कुछ?
>> [अंत वीडियो प्लेबैक]
>> डेविड मालन: ठीक है, शायद नहीं.
आप लोगों का तो कितने इन के साथ बड़ा हुआ?
ठीक है, तो यह कम और कम है हाथों हर वर्ष.
लेकिन मैं आपको कम से कम परिचित हैं खुश हूँ उनके साथ, क्योंकि यह और हमारे अपने
पुस्तक डेमो, अफसोस की बात है, एक बहुत ही मर रहे हैं यहां अपनेपन की मौत धीमी गति से.
>> लेकिन यह क्या मैं, कम से कम, पीठ में है उच्च विद्यालय, बैकअप के लिए इस्तेमाल का उपयोग करें.
और यह अद्भुत था क्योंकि आप 1.4 मेगाबाइट पर दुकान सकता है
इस विशेष डिस्क.
और इस उच्च घनत्व संस्करण था, जो है HD, ने संकेत दिया
आज की एचडी वीडियो से पहले अर्थ.
>> स्टैंडर्ड घनत्व 800 किलोबाइट था.
और उससे पहले, वहाँ थे 400 किलोबाइट डिस्क.
और उससे पहले, 5 और 1/4 वहाँ थे सही मायने में फ्लॉपी थे जो इंच डिस्क,,
और एक छोटे से व्यापक और लम्बे यहाँ इन बातों से.
लेकिन आप वास्तव में तथाकथित देख सकते हैं इन डिस्क के फ्लॉपी पहलू.
>> और कार्यात्मक, वे वास्तव में कर रहे हैं पर की हार्ड ड्राइव करने के लिए बहुत समान
कम से कम इस प्रकार के.
फिर, नए कंप्यूटर में SSDs एक छोटे से अलग काम करते हैं.
लेकिन आप उस छोटे से धातु टैब ले जाते हैं, आप वास्तव में एक छोटे कुकी देख सकते हैं,
या थाली.
>> यह यह एक तरह धातु नहीं है.
यह एक वास्तव में कुछ सस्ता है प्लास्टिक सामग्री.
और आप की तरह यह wiggle कर सकते हैं.
और तुम trully बस कुछ दूर मिटा दिया है बिट्स या चुंबकीय कणों की संख्या
इस डिस्क से.
>> तो शुक्र है, इस पर कुछ भी नहीं है.
और कवर - बात यह है कि रास्ते में है तो अपनी आँखें और अपने पड़ोसी के उन -
आप बस की तरह खींच कर सकते हैं पूरी तरह है कि बंद म्यान.
लेकिन एक छोटे से वसंत है, इसलिए हो सकता है अपनी आँखों से इस बात का पता.
तो अब आप सही मायने में एक फ्लॉपी डिस्क है.
>> और क्या इस बारे में उल्लेखनीय है है कि यह है जितना में एक
एक बड़े से छोटे पैमाने पर प्रतिनिधित्व हार्ड ड्राइव, इन बातों को, सुपर रहे हैं
सुपर सरल.
आपको लगता है कि अब यह के नीचे, चुटकी, तो धातु है कि बात के लिए रवाना, और छील
उन्हें खोलने, सब वहाँ के दो टुकड़े है महसूस किया और तथाकथित फ्लॉपी डिस्क
अंदर पर धातु का एक टुकड़ा के साथ.
>> और के आधे वहां से चला जाता है मेरी डिस्क की सामग्री.
उनमें से एक और आधा हो जाता है.
लेकिन वह अंदर कताई था वह सब है पहल साल में अपने कंप्यूटर की.
>> और फिर, परिप्रेक्ष्य में यह डाल, अपने से ज्यादातर कितना बड़ा है
कठिन इन दिनों ड्राइव?
500 गीगाबाइट, एक टेराबाइट, शायद में एक डेस्कटॉप कंप्यूटर, 2 टेराबाइट्स, 3
टेराबाइट्स, 4 टेराबाइट्स, सही?
यह एक मेगाबाइट, दे या ले है यहां तक कि एक ठेठ एमपी 3 फिट नहीं कर सकते जो
अब और इन दिनों, या कुछ इसी तरह संगीत फ़ाइल.
>> तो आप के लिए एक छोटी सी स्मारिका आज, और यह भी क्या contextualize मदद करने के लिए
हम के लिए दी ले जा सकता हूँ अब समस्या में पांच सेट.
तो उन तुम्हारा रखने के लिए कर रहे हैं.
तो मुझे कहाँ होगी करने के लिए संक्रमण करते हैं साथ ही अगले pset खर्च.
तो हम अब के लिए इस पेज को निर्धारित किया है - ओह, घोषणाओं के एक जोड़े को जल्दी से.
>> इस शुक्रवार, अगर आप चाहेंगे CS50 जुड़ने दोपहर के भोजन के लिए, सामान्य जगह पर जाना
cs50.net/rsvp.
और अंतिम परियोजना -
इसलिए सिलेबस के अनुसार, हम पोस्ट किया है पहले से ही अंतिम परियोजना विनिर्देश.
इसका मतलब यह नहीं है कि एहसास यह विशेष रूप से जल्द ही कारण है.
यह सिर्फ पाने के लिए, वास्तव में, तैनात है आप इसके बारे में सोच लड़के.
और वास्तव में, एक सुपर महत्वपूर्ण आप का प्रतिशत से निपटने की जाएगी
सामग्री पर अंतिम परियोजनाओं है कि हम यहां तक कि क्लास में करने के लिए नहीं मिल गया है,
लेकिन के रूप में अगले हफ्ते की शुरुआत के रूप में होगा.
>> सूचना, हालांकि, कल्पना के लिए कहता है की कुछ अलग घटकों
अंतिम परियोजना.
सबसे पहले, एक कुछ हफ्तों में, एक है पूर्व प्रस्ताव, एक सुंदर आकस्मिक ईमेल करने के लिए
अपने TF आप क्या कर रहे हैं उसे बता सकते हैं या करने के लिए साथ, अपनी परियोजना के बारे में सोच
कोई प्रतिबद्धता.
प्रस्ताव अपने विशेष होगा प्रतिबद्धता, कह रही है, यहाँ, यह क्या है
मैं अपनी परियोजना के लिए करना चाहते हैं.
आप क्या सोचते हैं?
बहुत बड़ा है?
बहुत छोटा?
यह प्रबंधनीय है?
और अगर आप अधिक जानकारी के लिए कल्पना देखते हैं.
>> उसके बाद सप्ताह की जोड़ी स्थिति है एक इसी तरह की है, जो रिपोर्ट
कहने के लिए अपने TF करने के लिए आकस्मिक ईमेल बस कैसे आप अपने अंतिम में हैं बहुत पीछे
द्वारा पीछा परियोजना के कार्यान्वयन, CS50 Hackathon जहाँ हर कोई
आमंत्रित किया है, से एक घटना होगी जो 7:00 तक एक शाम को 8:00
अगली सुबह हूँ.
मैं सप्ताह में उल्लेख किया है मई के रूप में पिज्जा, शून्य, 9:00 पर कार्य किया जा wil,
1:00 पर चीनी खाना.
और तुम अब भी 5:00 पर जाग रहे हैं, हम नाश्ते के लिए IHOP के लिए ले जाऊँगा.
>> तो Hackathon अधिक में से एक है वर्ग में यादगार अनुभव.
तब कार्यान्वयन की वजह से है, और तब चरम CS50 मेला.
इन सब के बारे में अधिक जानकारी आने वाले सप्ताहों में.
>> लेकिन कुछ करने के लिए वापस जाओ पुराने स्कूल -
फिर, एक सरणी.
इसे हल इसलिए क्योंकि एक सरणी, अच्छा था हम जैसी समस्याओं को देखा सिर्फ एक
छात्र संरचनाओं के साथ पहले पल एक छोटे से नियंत्रण से बाहर हो रही है अगर हम
छात्र एक, छात्र दो है चाहता हूँ, छात्र तीन, छात्र डॉट डॉट डॉट,
छात्रों में से कुछ मनमाना संख्या.
>> तो सरणियों, कुछ हफ्ते पहले, में swooped और नहीं के बारे में हमारी सभी समस्याओं का हल
अग्रिम में जानने कितनी बातें कुछ प्रकार के हम चाहते हो सकता है.
और हम structs हमारी मदद कर सकते हैं कि देखा है आगे हमारे कोड को संगठित करने और रखने के
एक तरह धारणात्मक समान चर, नाम और एक घर, एक साथ, ताकि हम
अंदर, एक इकाई के रूप में उन्हें इलाज कर सकते हैं छोटे टुकड़े कर रहे हैं जो की.
>> लेकिन सरणियों कुछ नुकसान है.
नुकसान की कुछ क्या हैं हम सामना करना पड़ा है
सरणियों के साथ इस प्रकार अब तक?
वह क्या है?
निश्चित आकार - तो भी आप कर सकते हैं, हालांकि एक के लिए स्मृति आवंटित करने में सक्षम हो
सरणी, आप कितने छात्रों को पता एक बार आपको लगता है कि कितने अक्षर है,
उपयोगकर्ता से, एक बार आप आवंटित किया है सरणी, आप की तरह चित्रित किया
एक कोने में अपने आप को.
>> आप नए तत्वों को सम्मिलित नहीं कर सकता, क्योंकि एक सरणी के बीच में.
आप अधिक तत्व सम्मिलित नहीं कर सकता एक सरणी के अंत में.
वास्तव में, यदि आप एक बनाने का सहारा हम चर्चा की है के रूप में पूरी नई सरणी,,
नई में पुराने नकल.
और फिर, कि सिर दर्द है कि आप के लिए के साथ सौदों GetString.
>> लेकिन फिर, आप भी सम्मिलित नहीं कर सकता सरणी के बीच में कुछ
दर पूरी तरह भरा नहीं है.
उदाहरण के लिए, अगर आकार के यहां इस सरणी छह ही, इसमें पांच बातें
ठीक है, तुम सिर्फ हमले कर सकता है अंत पर कुछ.
लेकिन अगर आप कुछ सम्मिलित करने के लिए क्या चाहते हैं के बीच में
यह हो सकता है, भले ही सरणी, पांच इसमें छह चीजों से बाहर?
>> हम सभी था जब खैर, हम क्या किया हमारे मानव स्वयंसेवकों मंच में की
सप्ताह पिछले?
हम या तो किसी को यहाँ डाल करना चाहते थे इस स्थानांतरित करने के लिए कैसे इन लोगों को
इस स्थानांतरित करने के लिए कैसे रास्ता, या इन लोगों जिस तरह से, और उस महंगा हो गया.
एक के अंदर लोगों का स्थानांतरण सरणी जोड़ने और लागत को समाप्त हो गया
हमें समय, हमारे n इसलिए बहुत चुकता के लिए, सम्मिलन सॉर्ट ऐसे समय चल रहा है
उदाहरण के लिए, सबसे खराब स्थिति में.
तो सरणियों महान हैं, लेकिन आप के लिए है आप चाहते हैं उन्हें कितना बड़ा पहले से पता है.
>> तो ठीक है, यहाँ एक समाधान है.
कितने मैं पहले से नहीं जानते हैं छात्रों मैं हो सकता है, और मैं एक बार पता
मैं हालांकि, मैं उस के साथ फँस गया हूँ, तय कई छात्रों, क्यों नहीं मैं तो बस हमेशा
दो बार के रूप में ज्यादा जगह आवंटित मैं मैं की जरूरत है लगता है कि शायद?
नहीं एक उचित समाधान है?
>> वास्तविक, मुझे लगता है हम कर रहे हैं कि नहीं लगता 50 से अधिक स्लॉट की जरूरत के लिए जा रहा
एक मध्यम आकार के वर्ग के लिए एक सरणी में, तो चलो बस को गोल करते हैं.
मैं सिर्फ अपने सरणी में 100 स्लॉटों कर दूँगा हम निश्चित रूप से प्राप्त कर सकते हैं
मुझे उम्मीद है छात्रों की संख्या के लिए कुछ मध्यम आकार के वर्ग में हो.
तो क्यों अभी तक दौर और आवंटित नहीं अधिक स्मृति, आम तौर पर, एक सरणी के लिए
आपको लगता है कि आप भी जरूरत हो सकती है?
इस सरल pushback क्या है यह विचार है कि करने के लिए?
>> तुम सिर्फ स्मृति बर्बाद कर रहे हैं.
आप तो लिखने सचमुच हर कार्यक्रम शायद दो बार के रूप में ज्यादा स्मृति के रूप में उपयोग कर रहा है
आप वास्तव में जरूरत है.
और वह सिर्फ एक तरह महसूस नहीं करता विशेष रूप से सुरुचिपूर्ण समाधान.
इसके अलावा, यह सिर्फ कम हो जाती है एक समस्या की संभावना.
आप एक लोकप्रिय कोर्स के लिए होता है एक सेमेस्टर और आप 101 है
छात्रों, अपने कार्यक्रम अभी भी है मूलरूप में एक ही मुद्दे का सामना करना पड़.
>> तो शुक्र है, वहाँ एक समाधान है फॉर्म में इस विज्ञापन हमारी सभी समस्याओं
हैं कि डेटा संरचनाओं की लोगों की तुलना में अधिक जटिल
हम इस प्रकार अब तक देखा है.
यह, मैं दावा, एक लिंक सूची है.
इस नंबर की एक सूची है -
9, 17, 22, 26, और 34 -
वैसे एक साथ जोड़ दिया गया है कि मैं तीर के रूप में तैयार किया है क्या की.
>> दूसरे शब्दों में, मैं प्रतिनिधित्व करना चाहता था एक सरणी, मैं क्या कर सकता
कुछ इस तरह.
और मैं भूमि के ऊपर पर डाल देता हूँ बस एक पल में.
मैं कर सकता है -
नमस्कार, सब ठीक है.
द्वारा खड़े हो जाओ.
यहां नई कंप्यूटर, साफ -
ठीक है.
>> तो मैं सरणी में इन नंबर हैं -
9, 17, 22, 26, 24 -
जरूरी नहीं पैमाने पर करने की.
ठीक है, तो यहाँ मेरे सरणी है -
हे भगवान.
ठीक है, तो यहाँ मेरे सरणी है.
हे भगवान.
>> [हंसी]
>> डेविड मालन: नाटक.
यह वापस जाने के लिए बहुत अधिक प्रयास है और इसलिए वहाँ, तय है कि -
26.
इसलिए हम इस सरणी है 9, 17, 22, 26, और 34.
आप में से उन देख सकते हैं शर्मनाक गलती मैं सिर्फ बनाया,
वहाँ यह है.
>> इसलिए मैं इस का दावा है कि एक बहुत ही कुशल समाधान.
मैं के रूप में कई ints आवंटित किया है मैं की जरूरत है - एक, दो, तीन,
चार, पांच या छह -
और मैं तो संख्या संग्रहीत किया है इस सरणी के अंदर.
लेकिन लगता है, तो, मैं सम्मिलित करना चाहते हैं 8 नंबर की तरह एक मूल्य है?
खैर, जहां यह जाना है?
मैं सम्मिलित करने के लिए चाहता हूँ 20 की तरह एक नंबर.
खैर, जहां यह जाना है?
कहीं बीच में, या संख्या 35 से जाना है
अंत में कहीं.
लेकिन मैं अंतरिक्ष के बाहर सब कर रहा हूँ.
>> और इसलिए यह एक मौलिक चुनौती है सरणियों का समाधान कर रहे हैं कि है.
मैं GetString, एक पल पहले दावा किया इस समस्या को हल करती है.
आप एक छठे नंबर डालने के लिए चाहते हैं इस सरणी में, कम से कम एक क्या है
आप सुनिश्चित करने के लिए पीठ पर गिर सकता है समाधान, हम GetString साथ बस पसंद नहीं है?
वह क्या है?
>> खैर, यह बड़ा है कर आसान काम से कहा.
हम जरूरी सरणी नहीं कर सकता बड़ा, लेकिन हम क्या कर सकते हैं?
आकार का बड़ा है कि एक नई सरणी, बनाओ 6, या शायद 10 आकार, अगर हम चाहते हैं
चीज़ों के आगे मिलता है, और फिर कॉपी करने के लिए तो नया है, और में पुराने सरणी
पुराने सरणी मुक्त.
>> लेकिन समय चल रहा है क्या है अब उस प्रक्रिया की?
यह, एन के बिग हे क्योंकि नकल आप में से कुछ इकाइयों खर्च हो रहा है
समय, तो हम ऐसा करने के लिए आदर्श है, अगर नहीं जा रहा है जो एक नई सरणी, आवंटित
दो बार के रूप में ज्यादा उपभोग करने के लिए स्मृति को अस्थायी रूप से.
नई में पुरानी कॉपी -
मेरा मतलब है, यह सिर्फ एक सिरदर्द है, जो , फिर से, हम क्यों लिखा है
आप के लिए GetString.
>> तो हम बजाय क्या कर सकता है?
खैर, क्या हुआ अगर हमारे डेटा संरचना वास्तव में यह अंतराल है?
मैं होने के अपने लक्ष्य को आराम कि मान लीजिए स्मृति के सन्निहित हिस्सा, जहां 9
ठीक बगल में 17 को, जो है 22 के बगल में, और इतने पर.
>> और 9 में यहाँ पर हो सकता है कि लगता है रैम, और 17, रैम में यहाँ पर हो सकता है
और 22 यहाँ रैम में खत्म हो सकता है.
दूसरे शब्दों में, मैं उन्हें जरूरत नहीं है यहां तक कि अब और वापस वापस.
मैं तो बस किसी तरह एक सुई धागा करने के लिए है इन नंबरों में से प्रत्येक, या प्रत्येक के माध्यम से
हम फोन करता हूँ इन नोड्स के, के रूप में मैं करने के लिए, उन्हें तैयार किया है के रूप में आयतों
पिछले करने के लिए प्राप्त करने के लिए कैसे याद पहले से ऐसी नोड.
>> तो प्रोग्रामिंग का निर्माण क्या है हम काफी हाल ही में देखा है, जिसके साथ मैं
उस धागे को लागू करने, या कर सकते हैं जिसके साथ मैं कर सकता हूँ, यहाँ तैयार
उन तीरों को लागू?
तो संकेत, सही?
मैं न सिर्फ एक आवंटित हैं INT, लेकिन एक नोड - और से
नोड, मैं सिर्फ कंटेनर मतलब.
और नेत्रहीन, मैं एक आयत का मतलब.
तो एक नोड जाहिरा तौर पर की जरूरत है दो मूल्यों को नियंत्रित करने के लिए -
के रूप में निहित, तो खुद INT, और आयत के नीचे आधा,
एक पूर्णांक के लिए पर्याप्त जगह.
>> तो बस, यहाँ आगे की सोच इस नोड यह कितना बड़ा है
प्रश्न में कंटेनर?
कितने बाइट्स int के लिए?
मुमकिन 4, अगर यह हमेशा की तरह ही है.
और फिर कितने बाइट्स सूचक के लिए?
4.
तो इस कंटेनर, या इस नोड है एक 8 बाइट संरचना होने जा रहा.
ओह, और कहा कि यह सुखद संयोग है कि हम सिर्फ इस धारणा की शुरुआत की
एक संरचना, या एक सी संरचना.
>> इसलिए मुझे लगता है मैं एक कदम उठाना चाहते हैं कि दावा यह और अधिक परिष्कृत की ओर
नंबरों की सूची के कार्यान्वयन, एक नंबरों की सूची जुड़ा है, मैं क्या करने की जरूरत है एक
थोड़ा अधिक सामने सोच और न सिर्फ एक पूर्णांक, लेकिन एक struct घोषित
मैं पारंपरिक, फोन करता हूँ कि यहाँ, नोड.
हम चाहते हैं कि कुछ भी कहते हैं, लेकिन हो सकता है नोड एक बहुत में विषयगत होने जा रहा है
चीजों की अब हम पर तलाश शुरू.
>> कि नोड के अंदर एक पूर्णांक n है.
और फिर इस वाक्य रचना, एक छोटे से पहली नज़र में अजीब -
संरचना नोड * अगले.
खैर सचित्र रूप से, कि क्या है?
उस के नीचे आधा है हमने देखा है कि आयत
बस एक पल पहले.
>> लेकिन क्यों मैं * संरचना नोड कह रहा हूँ * बस नोड के लिए विरोध के रूप में?
कि सूचक इशारा कर रहा है क्योंकि अगर अन्य नोड में, यह सिर्फ
एक नोड के पते.
यही कारण है कि हम क्या है के साथ संगत है इस प्रकार अब तक संकेत के बारे में चर्चा की.
मैं दावा करते हैं लेकिन क्यों, इस संरचना है नोड कहा जाता है, मैं संरचना कहना है
नोड यहाँ अंदर?
>> बिल्कुल सही.
यह सी. के प्रकार की एक बेवकूफ वास्तविकता है typedef, तो बात है, नहीं है
अभी तक हुआ.
सी सुपर शाब्दिक है.
यह करने के लिए अपने कोड शीर्ष पढ़ता सही करने के लिए छोड़ दिया तल,.
और उस पर कि अर्धविराम हिट जब तक लब्बोलुआब यह नहीं करता है लगता है क्या
एक डेटा प्रकार के रूप में मौजूद है?
नोड, बोली गंदें शब्द बोलना नोड.
>> लेकिन क्योंकि अधिक वाचाल की घोषणा मैं पहली पंक्ति पर किया था -
typedef struct नोड -
उससे पहले, पहली बार आया था, क्योंकि घुंघराले ब्रेसिज़, उस तरह की तरह है
बजना पूर्व शिक्षित कि, आप , मुझे एक संरचना दे पता है क्या
संरचना नोड कहा जाता है.
सच कहूँ तो, मैं चीजों को बुला पसंद नहीं है संरचना नोड, संरचना नोड सभी
मेरे कोड भर में.
लेकिन मैं केवल बस के अंदर, एक बार इसे इस्तेमाल करेंगे मैं इतना है कि प्रभावी ढंग से कर सकते हैं
, परिपत्र संदर्भ का एक तरह से नहीं बना दर असल अपने आप को, लेकिन एक के लिए एक सूचक
की एक और करने के लिए सूचक एक समान प्रकार.
>> तो यह पता चला है कि एक आंकड़ा संरचना पर इस तरह, कुछ नहीं है
हो सकता है कि आपरेशन हमारे लिए ब्याज की.
हम सम्मिलित करने के लिए चाहते हो सकता है इस प्रकार की सूची में.
हम हटाने के लिए चाहते हो सकता है इस तरह से एक सूची से.
हम एक के लिए सूची खोज करने के लिए चाहते हो सकता है मूल्य, या अधिक आम तौर पार.
और पार सिर्फ एक अच्छा तरीका की है बाएँ पर शुरू कह रही है और सभी कदम
सही तरीके से करने.
>> और यहां तक कि यह थोड़ा अधिक के साथ, नोटिस परिष्कृत डेटा संरचना, चलो
मुझे हम में से कुछ उधार ले सकते हैं कि प्रस्ताव पिछले दो हफ्तों के विचारों और
कहा जाता है एक समारोह को लागू इस तरह से खोज.
यह सच लौटने के लिए जा रहा है या कर रहा है झूठा, यह दर्शाता है, हाँ या
नहीं, पता सूची में है.
इसका दूसरा तर्क एक सूचक है सूची पर ही है, एक तो
एक नोड के लिए सूचक.
>> मैं फिर क्या करने जा रहा हूँ घोषित है एक अस्थायी चर.
हम कन्वेंशन द्वारा पीटीआर यह फोन करता हूँ सूचक के लिए.
और मैं यह करने के लिए बराबर आवंटित सूची की शुरुआत.
>> और अब जबकि पाश नोटिस.
इतने लंबे समय के सूचक बराबर नहीं है के रूप में अशक्त करने के लिए, मैं जाँच करने के लिए जा रहा हूँ.
सूचक तीर n के बराबर है में पारित किया गया था कि पता?
और एक मिनट रुको - नई वाक्यविन्यास का टुकड़ा.
तीर अचानक क्या है?
हाँ?
>> बिल्कुल सही.
तो, जबकि कुछ मिनट पहले, हम इस्तेमाल कुछ का उपयोग करने के लिए डॉट संकेतन
एक संरचना के अंदर, अगर चर आप संरचना नहीं है है
ही है, लेकिन एक संरचना पर कोई सूचक, शुक्र है, वाक्य रचना का एक टुकड़ा है कि
अंत में सहज ज्ञान युक्त समझ में आता है.
तीर सूचक का पालन करने का मतलब है, हमारे तीर आम तौर पर मतलब है की तरह
सचित्र रूप से, और पर जाना डेटा क्षेत्र के अंदर.
तो तीर डॉट के रूप में एक ही बात है, लेकिन आप एक सूचक है जब आप इसे उपयोग.
>> तो बस, तो संक्षिप्त करने के लिए करते हैं तो क्षेत्र संरचना के अंदर सूचक कहा जाता है
बराबर होती n के बराबर होती है, सच वापसी.
अन्यथा, यहाँ इस लाइन - सूचक अगले सूचक के बराबर होती है.
तो यह क्या कर रहा है, नोटिस, अगर मैं वर्तमान संरचना पर इशारा कर रहा हूँ
9, और 9 युक्त संख्या नहीं है मैं देख रहा हूँ लगता है - मैं देख रहा हूँ
N के लिए 50 के बराबर होती है -
मैं अपने अस्थायी सूचक अद्यतन करने के लिए जा रहा हूँ इस नोड पर बात नहीं करने के लिए
अब और नहीं, लेकिन सूचक तीर अगला, जो मुझे यहाँ रखा जा रहा है.
>> अब, मुझे एहसास हुआ कि एक बवंडर है परिचय.
बुधवार को, हम वास्तव में इस करूँगा कुछ मनुष्यों के साथ और कुछ और के साथ
एक धीमी गति से कोड.
लेकिन, पता ही अब हम अपने डेटा कर रहे हैं संरचनाओं और अधिक जटिल है, ताकि हमारे
एल्गोरिदम, अधिक कुशल प्राप्त कर सकते हैं जो के लिए अपेक्षित होने जा रहा है
pset छह, हम, फिर से, उन में लोड करते हैं 150,000 शब्द हैं, लेकिन ऐसा करने की जरूरत
कुशलतापूर्वक, और आदर्श रूप में, एक बना हमारे उपयोगकर्ताओं को नहीं में लिए चलता है कि कार्यक्रम
रेखीय, एन में चुकता, लेकिन में नहीं आदर्श में लगातार समय,.
>> हम बुधवार को देखेंगे.
>> अध्यक्ष: अगले CS50, डेविड में उसके आधार मामले को भूल जाता है.
>> डेविड मालन: और है कि आप भेजने कैसे है सी. क्या साथ पाठ संदेश -
>> [विभिन्न पाठ संदेश अधिसूचना ध्वनियों]