1 00:00:00,000 --> 00:00:09,780 >> [Musiikki soi] 2 00:00:09,780 --> 00:00:11,150 >> ZAMYLA Chan: Katsotaanpa puuttua takaisin. 3 00:00:11,150 --> 00:00:14,030 Recover on luultavasti suosikkini PSET, ja lähinnä koska mielestäni se on 4 00:00:14,030 --> 00:00:15,650 todella, todella siistiä. 5 00:00:15,650 --> 00:00:19,040 Periaatteessa olet antanut muisti kortisto, jossa 6 00:00:19,040 --> 00:00:20,900 kuvat on poistettu. 7 00:00:20,900 --> 00:00:23,650 Mutta mitä aiot tehdä, on palauttaa ne kaikki. 8 00:00:23,650 --> 00:00:24,250 >> OK. 9 00:00:24,250 --> 00:00:28,230 Joten se on todella jännittävää, mutta ehkä vähän uhkaava, koska olet 10 00:00:28,230 --> 00:00:32,430 annetaan tyhjä C-tiedosto ja sinun täytyy täyttää sen sisään 11 00:00:32,430 --> 00:00:36,250 OK, joten katsotaanpa rikkoa tätä hallittaviin osiin. 12 00:00:36,250 --> 00:00:38,160 Sinun kannattaa avata muistikortti tiedostojen. 13 00:00:38,160 --> 00:00:39,900 Tämä vaikuttaa helpolta. 14 00:00:39,900 --> 00:00:43,030 Sitten löytää alku JPG-kuvan. 15 00:00:43,030 --> 00:00:46,740 Kaikki tiedostot tämä muisti kortti aiotaan JPGs. 16 00:00:46,740 --> 00:00:50,840 Sitten, kun löydät alussa, aiot avata uuden JPG, että 17 00:00:50,840 --> 00:00:57,610 on, kuten, luoda JPG, ja kirjoittaa 512 tavu kerrallaan, kunnes uusi JPG on 18 00:00:57,610 --> 00:01:02,930 löytyi, ja päättyy ohjelman kerran havaitset tiedoston loppuun. 19 00:01:02,930 --> 00:01:06,400 >> Joten ensimmäiset askeleet ensin on avata muistikortti tiedostojen. 20 00:01:06,400 --> 00:01:09,850 Mutta te tiedätte tämän jo, ja siellä on tiedoston I / O-toiminto, joka tulee 21 00:01:09,850 --> 00:01:12,030 osoittautua erittäin hyödyllistä. 22 00:01:12,030 --> 00:01:12,820 OK. 23 00:01:12,820 --> 00:01:14,760 Joten mitä ovat JPGs? 24 00:01:14,760 --> 00:01:16,330 Koska meidän on alussa se. 25 00:01:16,330 --> 00:01:21,310 No, JPGs, kuten vähän karttoja, ovat vain sekvenssit tavua. 26 00:01:21,310 --> 00:01:30,660 Onneksi jokainen JPG alkaa joko 0xff, 0xd8, 0xFF, 0XE0, yksi sekvenssi 27 00:01:30,660 --> 00:01:33,610 tavujen tai muun sarja tavuja. 28 00:01:33,610 --> 00:01:37,250 >> Joten ne neljä tavua ilmaisevat alku JPG. 29 00:01:37,250 --> 00:01:40,780 Ei ole muita kuin nämä kaksi yhdistelmät neljä tavua. 30 00:01:40,780 --> 00:01:44,840 Ja onneksi meille, toinen tosiasia, että me voi hyödyntää on, että jokainen 31 00:01:44,840 --> 00:01:48,550 JPG on tallennettu side-by-side muistikortilla. 32 00:01:48,550 --> 00:01:52,210 Olen edusti rakenne muistikortti kaavamaisesti tästä 33 00:01:52,210 --> 00:01:53,310 dia täällä. 34 00:01:53,310 --> 00:01:59,270 Täällä jokainen neliö, joka suorakulmion, edustaa 512 tavua, ja se alkaa 35 00:01:59,270 --> 00:02:01,750 harmaa, että emme todella on JPG. 36 00:02:01,750 --> 00:02:05,700 >> Mutta sitten vihdoin osui lohko, jossa on tähti. 37 00:02:05,700 --> 00:02:10,940 Tämä tarkoittaa, että neljä ensimmäistä tavua ulos näistä 512 on yksi niistä kahdesta 38 00:02:10,940 --> 00:02:13,230 alkaen sekvenssit JPG. 39 00:02:13,230 --> 00:02:17,340 Ja me mennä sieltä, ja sitten kerran yksi JPG päättyy, seuraava alkaa. 40 00:02:17,340 --> 00:02:20,990 Meillä ei koskaan ole enempää harmaa tilaa siltä väliltä. 41 00:02:20,990 --> 00:02:25,550 >> Mutta miten voimme todella lukea tätä, ja Lue 512 tavua, jotta voimme tehdä 42 00:02:25,550 --> 00:02:27,500 Vertailun ensimmäinen paikka? 43 00:02:27,500 --> 00:02:33,470 No, mennään takaisin fread, joka vie struct, joka sisältää 44 00:02:33,470 --> 00:02:34,470 tavua, että luet. 45 00:02:34,470 --> 00:02:36,570 Joten aiot laittaa niitä siellä - 46 00:02:36,570 --> 00:02:42,192 koko, lukumäärä, ja sitten inpointer että luet alkaen. 47 00:02:42,192 --> 00:02:49,900 Nyt haluamme lukea 512 kerrallaan, ja haluamme säilyttää tämän puskurissa, 48 00:02:49,900 --> 00:02:50,700 Aion kutsua sitä. 49 00:02:50,700 --> 00:02:54,100 >> Periaatteessa aiomme pitää asemia 512 tavua ja tehdä 50 00:02:54,100 --> 00:02:55,500 asioita sen kanssa, eikö? 51 00:02:55,500 --> 00:02:58,260 Me joko menossa verrata ensin neljä tavua tai aiomme 52 00:02:58,260 --> 00:02:59,830 lukea se, OK? 53 00:02:59,830 --> 00:03:05,050 Joten sitten datan osoitin sitten toimii teidän puskuri, ja 54 00:03:05,050 --> 00:03:07,745 inpointer, hyvin, että on juuri menossa olla muistikortille. 55 00:03:07,745 --> 00:03:09,500 >> Takaisin meidän muistikortille kaavamainen. 56 00:03:09,500 --> 00:03:14,690 Aiomme lukea 512 tavua kerrallaan, tallentamiseen jokaisen 512 tavun lohko 57 00:03:14,690 --> 00:03:19,190 puskuriin, pitää kiinni ne, puskuri, nämä 512 tavua, ennen kuin tiedämme 58 00:03:19,190 --> 00:03:22,000 mitä tehdä niille. 59 00:03:22,000 --> 00:03:25,960 Joten alussa ei ole mitään, niin me lukea puskuri, verrata sitä, ja 60 00:03:25,960 --> 00:03:28,160 meidän ei tarvitse tehdä mitään sen kanssa. 61 00:03:28,160 --> 00:03:32,030 Ja sitten vihdoin osui tähti lohko, mikä tarkoittaa, että olemme 62 00:03:32,030 --> 00:03:33,630 löytyi ensimmäinen JPG. 63 00:03:33,630 --> 00:03:36,560 Joten puskuri nyt pitää tavuja että JPG. 64 00:03:36,560 --> 00:03:40,220 >> Seuraavan kerran 512 tavua, koska he ei tähti lohko, ovat myös 65 00:03:40,220 --> 00:03:41,740 osa tätä JPG. 66 00:03:41,740 --> 00:03:47,630 Ja JPGs ovat jatkuvia sieltä sisään, kunnes osuimme ensi JPG. 67 00:03:47,630 --> 00:03:51,880 Ja sitten puskuri sitten omistaa 512 tavua, joka JPG, ja 68 00:03:51,880 --> 00:03:53,580 niin edelleen, ja niin edelleen. 69 00:03:53,580 --> 00:03:54,250 OK. 70 00:03:54,250 --> 00:03:58,980 >> Joten kun osut ensin tähdillä palkittu lohko, ensin JPG, miten te 71 00:03:58,980 --> 00:04:01,910 todella hyvin, avaa se? 72 00:04:01,910 --> 00:04:04,990 Tehdään uusi JPG. 73 00:04:04,990 --> 00:04:08,846 Tiedostonimiä JPG menossa oltava muodossa, numero, lukumäärä, 74 00:04:08,846 --> 00:04:13,830 number.jpg, että he nimetty siinä järjestyksessä, jossa ne esiintyvät, 75 00:04:13,830 --> 00:04:14,780 alkaen 0. 76 00:04:14,780 --> 00:04:19,890 >> Joten ensimmäinen JPG, että olet löytää tullaan 000.jpg. 77 00:04:19,890 --> 00:04:26,560 Joten, luultavasti hyvä idea seurata kuinka monta JPGs olet löytänyt tähän mennessä. 78 00:04:26,560 --> 00:04:27,610 Niin, että tiedoston nimi. 79 00:04:27,610 --> 00:04:29,660 Mutta miten voit itse tehdä, että? 80 00:04:29,660 --> 00:04:34,310 No, me aiomme käyttää toiminto nimeltään sprintf. 81 00:04:34,310 --> 00:04:38,260 Hieman samanlainen printf, jossa voit käyttää paikanpitäjinä jouset, 82 00:04:38,260 --> 00:04:42,420 paitsi että tässä tapauksessa sprintf tulostaa tiedoston ulos nykyisestä 83 00:04:42,420 --> 00:04:45,550 hakemistoon, ei terminaaliin. 84 00:04:45,550 --> 00:04:46,120 >> OK. 85 00:04:46,120 --> 00:04:49,950 Joten tässä me näemme, että meillä on otsikko, char array, joka tallentaa 86 00:04:49,950 --> 00:04:55,120 tuloksena merkkijono, ja me kulkea otsikko todellinen merkkijonon 87 00:04:55,120 --> 00:04:58,720 paikanvaraajassa aivan kuten olemme oppinut tekemistä printf. 88 00:04:58,720 --> 00:05:05,530 Mutta tämä koodi, joka minulla on täällä antaa 2.jpg, ei 002.jpg. 89 00:05:05,530 --> 00:05:09,920 Joten Jätän voit selvittää, miten muokata paikkamerkki tehdä 90 00:05:09,920 --> 00:05:11,920 oikea nimi. 91 00:05:11,920 --> 00:05:12,610 >> OK. 92 00:05:12,610 --> 00:05:17,390 Joten kun olet sprintf'd sitten voit avaa tiedoston, koska se on olemassa 93 00:05:17,390 --> 00:05:22,690 hakemistoon, jossa fopen käyttäen otsikko, ja sitten mitä haluamasi tila 94 00:05:22,690 --> 00:05:25,140 avata tiedoston sisään 95 00:05:25,140 --> 00:05:30,260 Joten nyt olemme avannut uuden JPG-tiedosto, Nyt voimme kirjoittaa 512 tavua 96 00:05:30,260 --> 00:05:33,320 aikaa, kunnes uusi JPG löytyy. 97 00:05:33,320 --> 00:05:36,640 Joten katsotaanpa katsomaan uudelleen klo syntaksi fwrite. 98 00:05:36,640 --> 00:05:40,060 >> Tiedän, että näytän tämän dian paljon, mutta haluan vain varmistaa, että 99 00:05:40,060 --> 00:05:43,530 te älä mene liian sekava, koska Tiedän, että se on erittäin helppo 100 00:05:43,530 --> 00:05:47,000 sekoittaa ensimmäinen ja viimeinen argumentti, erityisesti. 101 00:05:47,000 --> 00:05:54,390 Mutta muista, että olet kirjallisesti teidän puskuri pois tiedostojen näkymiä. 102 00:05:54,390 --> 00:05:59,250 >> Nyt kun tiedät miten kirjoittaa 512 tavut omalle JPG-tiedosto, joka olet 103 00:05:59,250 --> 00:06:03,230 luotu, hyvin, haluamme lopettaa että prosessia, kun olemme saavuttaneet lopussa 104 00:06:03,230 --> 00:06:06,720 Meidän kortti, koska siellä ei ole enempää kuvia löytyy. 105 00:06:06,720 --> 00:06:10,760 Joten mennään takaisin fread kerran, lupaan. 106 00:06:10,760 --> 00:06:15,600 fread palauttaa kuinka monta kohdetta koosta, koko, valmistuivat onnistuneesti. 107 00:06:15,600 --> 00:06:19,440 Ihannetapauksessa tämä tulee olemaan mitä tahansa ohitat numeron, eikö? 108 00:06:19,440 --> 00:06:24,140 Koska yrität lukea numeron elementtien koon, kokoa. 109 00:06:24,140 --> 00:06:29,380 Mutta jos fread ei voi lukea, että alkioiden lukumäärä, niin se tulee palauttaa 110 00:06:29,380 --> 00:06:32,530 mitä numero se lukenut onnistuneesti. 111 00:06:32,530 --> 00:06:36,310 >> Nyt yksi tärkeä asia huomata on että jos käytät toisen tiedoston I / O 112 00:06:36,310 --> 00:06:43,860 toimivat kuten fgetc, se tulee myös palata kuinka monta kohdetta se lukea onnistuneesti. 113 00:06:43,860 --> 00:06:48,000 Mitä hyötyä tästä toiminnosta on että jos käytät toimintoja sisällä 114 00:06:48,000 --> 00:06:53,190 kunnossa, se tulee suorittaa itse taas määritetään, että ehto, joka on 115 00:06:53,190 --> 00:06:54,340 vain todella hyödyllinen. 116 00:06:54,340 --> 00:07:00,440 Joten jos sinulla on tämä olosuhteissa, vaikkapa jos fread puskuri, sizeof koira, 2, 117 00:07:00,440 --> 00:07:04,870 osoitin, vastaa on 1, että tarkoittaa sitä, että haluaisin lukea 118 00:07:04,870 --> 00:07:06,540 2 koiraa tuolloin. 119 00:07:06,540 --> 00:07:13,490 Mutta jos fread palauttaa 1 eikä 2 kuten odotettavissa, se tarkoittaa, että on olemassa 2 120 00:07:13,490 --> 00:07:16,480 koirat jäljellä tiedostoni, vaan 1. 121 00:07:16,480 --> 00:07:22,450 Mutta jos se palaa 2, niin minulla on vielä nämä 2 koiraa sisällä minun puskuria. 122 00:07:22,450 --> 00:07:26,280 >> Joten nyt joka antaa sinulle tunteen, miten Tarkista tiedoston loppuun, mutta 123 00:07:26,280 --> 00:07:28,940 mennään läpi nyt logiikkaa. 124 00:07:28,940 --> 00:07:32,460 Miten me oikeastaan ​​pala kaikki nämä yhdessä? 125 00:07:32,460 --> 00:07:36,880 Kun me iski ensimmäisen JPG, sillä Tiedämme, että JPGs on tallennettu 126 00:07:36,880 --> 00:07:40,910 contiguously, me voidaan kirjallisesti ennen pääsemme loppuun kortisto. 127 00:07:40,910 --> 00:07:43,950 Mutta emme halua kirjoittaa mitään siihen saakka. 128 00:07:43,950 --> 00:07:48,710 Joten sillä on merkitystä, ei vain, että me olemme aloitettiin uusi JPG, mutta onko 129 00:07:48,710 --> 00:07:50,655 olemme jo löytäneet JPG vai ei. 130 00:07:50,655 --> 00:07:55,390 >> Jos se on alku uuden JPG käymme haluat sulkea nykyisen JPG-tiedosto, jos 131 00:07:55,390 --> 00:07:59,110 meillä on yksi avoin, ja avoin uusi kirjoittaa osaksi. 132 00:07:59,110 --> 00:08:03,340 Jos se ei ole aloittaa uuden JPG, vaikka, me jatkamme samaa JPG-tiedosto 133 00:08:03,340 --> 00:08:05,910 avata ja kirjoittaa siihen. 134 00:08:05,910 --> 00:08:10,100 Me kirjoitamme puskuri kumpi JPG-tiedosto meillä on käytettävissä, edellyttäen että 135 00:08:10,100 --> 00:08:12,120 meillä on yksi avoin, tietenkin. 136 00:08:12,120 --> 00:08:16,190 Jos emme ole löytäneet meidän ensimmäinen JPG vielä, emme kirjoita mitään. 137 00:08:16,190 --> 00:08:20,290 Ja tämä prosessi jatkuu, kunnes päähän kortisto. 138 00:08:20,290 --> 00:08:23,410 >> Ja lopuksi, sinun kannattaa tehdä Varmista, että olet FSulje mitään 139 00:08:23,410 --> 00:08:25,800 tiedostot, jotka olet fopened. 140 00:08:25,800 --> 00:08:28,360 Kun olet tyytyväinen käsitteitä, katsomaan joitakin 141 00:08:28,360 --> 00:08:30,840 pseudokoodina, jonka olen mukana tässä. 142 00:08:30,840 --> 00:08:34,830 Ensin kannattaa avata kortisto, ja toista sitten seuraava prosessi 143 00:08:34,830 --> 00:08:37,144 kunnes olet saavuttanut kortin päähän. 144 00:08:37,144 --> 00:08:40,880 Haluat lukea 512 tavua puskuriin. 145 00:08:40,880 --> 00:08:43,934 Käyttämällä että puskuri, sinun kannattaa tarkistaa olitpa alussa 146 00:08:43,934 --> 00:08:45,300 uusi JPG vai ei. 147 00:08:45,300 --> 00:08:48,400 Ja vastaus tähän kysymykseen vaikuttaa tiedostojen hallinta - 148 00:08:48,400 --> 00:08:51,940 mitkä tiedostot avaat, joka niistä suljet. 149 00:08:51,940 --> 00:08:55,220 >> Sitten, oletko jo löytänyt JPG? 150 00:08:55,220 --> 00:08:57,740 Miten olet ollut pitää seurata, että? 151 00:08:57,740 --> 00:09:01,735 Sitten, riippuen siitä, että sinun on joko kirjoittaa nykyiseen JPG, että olet 152 00:09:01,735 --> 00:09:07,090 on avoin tai ei kirjoita sitä ollenkaan, koska et ole löytänyt JPG vielä. 153 00:09:07,090 --> 00:09:10,870 Lopuksi, kun olet saavuttanut loppuun tiedoston, sinun kannattaa sulkea 154 00:09:10,870 --> 00:09:12,590 Jäljellä tiedostoja, sinulla on auki. 155 00:09:12,590 --> 00:09:14,590 Haluamme olla siisti täällä. 156 00:09:14,590 --> 00:09:18,790 >> Ja että, olet toipunut kaikki puuttuvia tiedostoja että muisti 157 00:09:18,790 --> 00:09:21,620 kortti, joka on melko uskomatonta feat. 158 00:09:21,620 --> 00:09:23,430 Joten taputtaa itseäsi selkään. 159 00:09:23,430 --> 00:09:27,560 Mutta, vielä yksi tekijä PSET, joka on kilpailu. 160 00:09:27,560 --> 00:09:30,920 Tulet huomaamaan, että kaikki kuvat että olet toipunut todella 161 00:09:30,920 --> 00:09:32,820 kuvia CS50: n henkilöstöä. 162 00:09:32,820 --> 00:09:38,500 Joten jos olet oppilaitoksen tai jonnekin lähellä, niin voit ottaa kuvia 163 00:09:38,500 --> 00:09:42,600 henkilökunta ja osa, joka on useimmat kuvat toimihenkilön 164 00:09:42,600 --> 00:09:46,940 niiden Palautetut tiedostot saada mahtava palkinto. 165 00:09:46,940 --> 00:09:50,650 Kanssa, että niin olet valmis takaisin PSET. 166 00:09:50,650 --> 00:09:53,600 Nimeni on Zamyla, ja tämä on CS50. 167 00:09:53,600 --> 00:10:01,835