1 00:00:00,000 --> 00:00:00,180 2 00:00:00,180 --> 00:00:02,920 >> SPEAKER 1: Kirjoitetaan ohjelma, joka saa merkkijonon käyttäjä ilman 3 00:00:02,920 --> 00:00:05,700 käyttäen CS50 kirjaston toimiakseen getString. 4 00:00:05,700 --> 00:00:08,720 Voit tehdä tämän, me menemme eteenpäin ja käyttää scanf, toiminto, joka getString 5 00:00:08,720 --> 00:00:10,950 toiminto itse asiassa käyttää alla huppu. 6 00:00:10,950 --> 00:00:13,780 Mutta aion tehdä tämän tarkoituksella in buginen tavalla. 7 00:00:13,780 --> 00:00:17,230 Aion tehdä tavalla, joka mielestäni olisi oikea, mutta käy ilmi, että 8 00:00:17,230 --> 00:00:19,380 oletan tulee olla varsin, varsin puutteellinen. 9 00:00:19,380 --> 00:00:20,800 Ja itse asiassa aika vaarallista. 10 00:00:20,800 --> 00:00:24,750 Koska vikoja jollainen olen aikeissa Merkki voidaan hyödyntää vastustajien 11 00:00:24,750 --> 00:00:28,870 siten, että koneesi tai ohjelmaan voidaan hyväksyä mahdollisesti. 12 00:00:28,870 --> 00:00:30,200 >> Aloitetaan seuraavasti. 13 00:00:30,200 --> 00:00:33,540 Katsotaanpa ensin julistamme merkkijono, joka tunnetaan nyt char tähti, 14 00:00:33,540 --> 00:00:34,750 ja kutsua sitä s. 15 00:00:34,750 --> 00:00:39,400 Lets vieressä pyytää käyttäjältä merkkijonon, kuten "merkkijono kiitos." Ja 16 00:00:39,400 --> 00:00:44,250 Katsotaanpa nyt saada merkkijonon käyttäjä käyttäen scanf, lainaus lainaus, "% s." Sisään 17 00:00:44,250 --> 00:00:47,760 Toisin sanoen, nyt ilmoittaa scanf että me eivät itse asiassa odottaa saavansa merkkijono 18 00:00:47,760 --> 00:00:48,630 käyttäjältä. 19 00:00:48,630 --> 00:00:50,810 >> Mutta nyt meidän täytyy kertoa scanf yksi muu asia - 20 00:00:50,810 --> 00:00:53,350 mihin merkkijono, joka käyttäjä antaa. 21 00:00:53,350 --> 00:00:57,840 No, aion yksinkertaisesti aloittaa pilkulla s, täsmennetään, että haluaisin 22 00:00:57,840 --> 00:00:59,320 scanf laittaa merkkijonon siellä. 23 00:00:59,320 --> 00:01:04,818 Olen vieressä menossa tulostaa jotain kuten printf "kiitos% s 24 00:01:04,818 --> 00:01:10,670 kenoviiva n pilkku. "Ja kuten aina, olen menossa ohi merkkijonon, s. 25 00:01:10,670 --> 00:01:14,920 Nyt tallentaa, kääntää ja ajaa tämän ohjelma, ja katso jos emme voi aiheuttaa 26 00:01:14,920 --> 00:01:16,590 ongelma minulla ennusti. 27 00:01:16,590 --> 00:01:18,650 >> Tee scanf-1. 28 00:01:18,650 --> 00:01:20,960 ./scanf-1. 29 00:01:20,960 --> 00:01:21,830 String kiitos. 30 00:01:21,830 --> 00:01:25,540 Katsotaanpa tarjota jotain, "Hei." "Kiitos null." Hmm, se ei ole 31 00:01:25,540 --> 00:01:26,750 mitä odotin. 32 00:01:26,750 --> 00:01:28,240 Joten mitä täällä tapahtuu? 33 00:01:28,240 --> 00:01:32,040 >> No, se kääntyy pois, koska me julisti s char tähden mutta emme 34 00:01:32,040 --> 00:01:36,120 tosiasiallisesti varastoitu s osoite todellinen kimpale muisti, scanf ei 35 00:01:36,120 --> 00:01:38,940 ole paikkaa laittaa merkkijonon että käyttäjän kirjoitetaan sisään 36 00:01:38,940 --> 00:01:42,510 Itse asiassa, jos käyttäjä oli nyt kirjoittaa paljon pidempi merkkijono kuin "hei" 37 00:01:42,510 --> 00:01:46,780 esimerkiksi useita rivejä tekstiä tai useita kappaleita tekstiä, se on melko 38 00:01:46,780 --> 00:01:50,280 mahdollista, että voisimme aiheuttaa ns segmentointi vika. 39 00:01:50,280 --> 00:01:53,570 >> Koska scanf ei tule tietää, että En ole itse laittaa osoitteen 40 00:01:53,570 --> 00:01:54,610 sisällä s. 41 00:01:54,610 --> 00:01:58,000 Pikemminkin se tulee nähdä jotain arvoa s, jotkut malli bittien voi 42 00:01:58,000 --> 00:02:00,910 hyvinkin olla roskat arvo, siellä vain sattumalta. 43 00:02:00,910 --> 00:02:04,600 Ja scanf on vielä menossa yrittää kirjoittaa Käyttäjä merkkijono kyseiseen osoitteeseen, 44 00:02:04,600 --> 00:02:08,789 vaikka se on roskaa arvo, joka voisi todellakin aiheuttaa kaatumisen. 45 00:02:08,789 --> 00:02:10,130 >> Joten miten aiomme korjata tämän? 46 00:02:10,130 --> 00:02:12,523