![]() |
| | ||||
| ||||
Standart Input/Output BASITIO.C: ================================================== ============== Kod: #include /* input/output icin standard header */main(){char c;printf("Herhangi bir tusa basin. X = Programi durdurur. ");do {c = getchar(); /* klavyeden bir tus okuyalim */putchar(c); /* ekranda gosterelim. */} while (c != 'X'); /* ta ki okunan bir X oluncaya dek... */printf(" Programin sonu. ");} Standart I/O deyimi, verinin girildigi ve ciktigi en normal yerleri, klavyeyi ve ekrani kast eder. Bu kutuge ilk baktiginizda, "#include " komutunu goreceksiniz. Bu komut on-derleyiciye, kucuktur ve buyuktur isaretleri arasinda yer alan kutuk isminin programa eklenmesini soyler. Bazen, < > isaretleri yerine den-den " " isaretleri de gorebilirsiniz. Aralarindaki fark, <> isaretlerinin on-derleyiciye, su anda calistiginiz diskte / dizinde degil de, bu tip kutuklerin konuldugu yerde aramasini bildirir. Halbuki den-den isaretleri ile belirlenmis bir kutuk ismi, sizin su anda bulundugunuz disk / dizinde aranir. Genellikle, "bu tip kutuklerin konuldugu yer", derleyiciye daha onceden belirtilir. Ornegin, Quick C derleyicisinde, derleyiciye girmeden once: SET INCLUDE=C:INCLUDE yazmak, derleyicinin bundan sonra butun 'include' edilecek, yani eklenecek kutuklerin C: diskinin INCLUDE dizininde aranmasini belirtir. Sonu .h ile biten kutuklerin, ozel bir fonksiyonu vardir. Bunlara header yada baslik kutukleri denir. Genellikle iclerinde, bazi fonksiyonlari kullanmak icin gereken tanimlamalar yer alir. Bu kullandigimiz "stdio.h" kutugu ise, bir suru "#define" komutundan olusur. C DE INPUT/OUTPUT ISLEMLERI C dilinde lisanin bir parcasi olarak tanimlanmis input/output komutlari yoktur, bu nedenle bu fonksiyonlarin kullanici tarafindan yazilmasi gereklidir. Her C kullanan kisi, kendi input/output komutlarini yazmak istemediginden, derleyici yazarlari bu konuda calisma yapmislar, ve bize bir suru input/output fonksiyonlari saglamislardir. Bu fonksiyonlar standart hale gelmislerdir, ve hemen her C derleyicisinde ayni input/output komutlarini bulabilirsiniz. C nin lisan tanimi, Kernigan ve Richie tarafindan yazilmis bir kitaptir, ve onlar bu gorecegimiz input/output fonksiyonlari bu kitaba katmislardir. Bu "stdio.h" isimli kutugu incelemenizde fayda vardir. Icinde bircok anlamadiginiz nokta olacaktir, fakat bazi kisimlar tanidik olacaktir. DIGER INCLUDE KUTUKLERI C de buyuk programlar yazmaya basladiginizda, programlari ufak parcalara ayirip ayri ayri derlemek isteyebilirsiniz. Bu degisik parcalarin ortak kisimlarini tek bir kutukte toplayip, bir degisiklik gerektiginde sadece o ortak kutukten yapmayi isteyebilirsiniz (ornegin global degisken tanimlari.) Bu gibi durumlarda "#include" kutukleri cok faydali olacaktir. "BASITIO" YA GERI DONELIM "c" isimli degisken tanimlanir, ve ekrana mesaj yazilir. Daha sonra, kendimizi "c", buyuk harf X e esit olmadigi surece devam eden bir dongunun icinde buluyoruz. Bu programdaki iki yeni fonksiyon, su an icin ilgi noktamiz. Bunlar klavyeden bir tus okumak, ve ekrana bir karakter yazmayi saglarlar. "getchar()" isimli fonksiyon, klavyeden okudugu tusu dondurur, bu deger "c" ye atanir. "putchar()" fonksiyonu ise, bu degeri ekrana yansitir. Bu programi derleyip calistirdiginizda, bir surpriz ile karsilasacaksiniz. Klavyeden yazdiginizda, ekrana herseyin iyi bir sekilde yansitildigini goreceksiniz. RETURN tusuna bastiginizda ise, butun satirin tekrar ekrana yazildigini goreceksiniz. Her karakteri teker teker ekrana getirmesini soyledigimiz halde, programimiz sanki butun satiri sakliyor gibi. DOS BIZE YARDIMCI OLUYOR (YADA ISE KARISIYOR) Bu durumu anlayabilmek icin, DOS un nasil calistigini anlamamiz gereklidir. Klavyeden tuslar DOS kontrolu ile okundugu zaman, RETURN tusu basilana dek, basilan tuslar bir sahada saklanir. RETURN basilinca da, butun satir programa dondurulur. Tuslara basilirken, karakterler ekrana da yansitilir. Bu duruma da "eko" ismi verilir. Simdi anlatilanlari goz onunde bulundurarak, programimiz calisirken ekrana eko edilenlerin, DOS tarafindan yapildigini anlayabilirsiniz. Siz RETURN e basinca da, bu saklanan tuslar, programa gonderilir. Bunu daha iyi anlamak icin, icinde buyuk harf X olan bir satir yazin. DOS, buyuk X in ozel bir tus oldugundan habersiz, siz RETURN e basana kadar tuslari kabul etmeye devam eder. RETURN e basinca ise, bu katar programa gecirilir, ve program X e rastlayincaya kadar ekrana karakterleri birer birer yazar. Isletim sisteminin bu tuhafliklari karsisinda yilmayin. Bazi programlarinizda, bu ozellik isinize yarayabilir. Fakat simdi biz, az once yazdigimiz programin, dusundugumuz gibi calismasini saglayalim. TEKIO.C: ================================================== ============== Kod: #include main(){char c;printf("Herhangi bir tusa basin. X = Programi durdurur. ");do {c = getch(); /* bir tus oku */putchar(c); /* basilan tusu goster */} while (c != 'X'); /* ta ki c == 'X' olana dek */printf(" Programin sonu. ");} Bu programdaki yegane degisiklik olan yeni fonksiyon "getch()", yine klavyeden tek bir karakter okur. Farki, "getchar" gibi DOS'a takilmamasidir. Bir karakter okur, ve ekrana yansitmadan bu tusu programa dondurur. Bu programi calistirdiginizda, bir oncekindeki gibi tekrarlanan satirlar olmadigini goreceksiniz. Ayrica program artik 'X' e basar basmaz durmaktadir. Burada baska bir problemimiz var. RETURN'e basinca cursor, ekranin soluna gitmektedir, ama bir alt satira inmemektedir. SATIR ATLAMAMIZ LAZIM Cogu uygulama programi siz RETURN e basinca, program o RETURN e ek olarak bir de "Line Feed" yani satir atlama karakteri ilave eder. Satir atlama otomatik olarak yapilmaz. Bundan sonraki programda, bu sorunu da halletmis olacagiz. IYIIO.C: ================================================== ============== Kod: #include "stdio.h"#define CR 13 /* CR sembolunu 13 olarak tanimlar */#define LF 10 /* LF sembolunu 10 olarak tanimlar */main(){char c;printf("Tuslara basin. Durmak icin X e basin. ");do {c = getch(); /* Bir karakter oku */putchar(c); /* basilan tusu ekrana yaz */if (c == CR) putchar(LF); /* sayet basilan RETURN tusu ise,bir SATIR ATLAMA karakteri yolla */} while (c != 'X');printf(" Programin sonu. ");} Programin ilk basinda CR 'nin artik 13 e esit oldugunu ve LF nin de 10 oldugunu belirtiyoruz. Sayet ASCII tablosundan bakarsaniz, RETURN tusuna karsilik gelen kodun 13 oldugunu gorursunuz. Ayni tabloda, satir atlama kodu da 10 dur. Ekrana basilan tusu yazdiktan sonra, sayet bu tus RETURN tusu ise, bir satir atlayabilmemiz icin, satir atlama kodunu ekrana yaziyoruz. Programin basindaki "#define" lar yerine "if (c == 13) putchar(10);" diyebilirdik, fakat ne yapmak istedigimiz pek belirgin olmazdi. HANGI METOD DAHA IYI? Burada ekrandan bir harf okumanin iki yolunu inceledik. Her ikisinin de avantajlari ve dezavantajlari var. Bunlara bir bakalim. Ilk metodda, butun isi DOS ustlenmektedir. Programimiz baska islerle ugrasirken, DOS bizim icin satiri hazirlayabilir, ve RETURN'e basilinca bu satiri programa dondurebilir. Fakat, bu metodda karakterleri basildiklari anda fark etmemiz imkansizdir. Ikinci metodda, tuslari teker teker fark etmemiz mumkundur. Fakat, program bu okuma sirasinda butun zamanini okumaya harcar ve baska bir is yapamaz, ve bilgisayarin tum zamanini bu isle almis oluruz. Hangi metodun uzerinde calistiginiz program icin daha uygun oldugunu programci olarak siz karar vereceksiniz. Burada, "getch()" fonksiyonun tersi olan "ungetch()" isimli bir fonksiyon daha oldugunu da belirtmeliyim. Sayet bir karakteri "getch()" le okuduktan sonra fazla okudugunuzu fark ederseniz, bu fonksiyon ile okunan tusu geri koyabilirsiniz. Bu bazi programlarin yazilimini kolaylastirmaktadir cunku bir tusu istemediginizi onu okuyuncaya kadar bilemezsiniz. Sadece bir tek tusu "ungetch" edebilirsiniz, fakat genellikle bu yeterlidir. BIRAZ TAMSAYI OKUYALIM TAMOKU.C: ================================================== ============== Kod: #include main(){int deger;printf("0 ila 32767 arasinda bir rakam yazin, durmak icin 100 girin. ");do {scanf("%d",°er); /* bir tamsayi oku (adresi ile) */printf("Okunan deger %d idi. ",deger);} while (deger != 100);printf("Programin sonu ");} Alistigimiz tip bir program olan TAMOKU'da, "scanf" isimli yeni bir fonksiyon goruyoruz. Cok kullandigimiz "printf" fonksiyonuna cok benzeyen bu fonksiyonun gorevi, istenilen tip verileri okuyup, degiskenlere atamak. "printf" den en buyuk farki, "scanf" in degisken degerleri yerine, adreslerini kullanmasidir. Hatirlayacaginiz gibi, bir fonksiyonun parametrelerinin degerlerini degistirebilmesi icin, degiskenin adresine ihtiyaci vardir. "scanf" fonksiyonuna adres yerine deger gecirmek, C dilinde en SIK rastlanan hatalardan biridir. "scanf" fonksiyonu, girilen satiri, satirdaki bosluklara bakmadan, ve bu sekilde kullanildiginda, rakam olmayan bir karakter bulana kadar bir tamsayi okur. Sayet 32766 den buyuk bir rakam girerseniz, programin hata yaptigini gorursunuz. Ornegin 65536 girerseniz, programin 0 degerini dondurdugunu gorursunuz. Buna sebep, tamsayilarin hafizada saklanisinda onlara 16 bitlik bir saha ayrilmasindandir. Programinizda daha buyuk rakamlar kullanacaksaniz, 'long' yada 'float' tiplerini secebilirsiniz. |
| "Standart Input/Output" konusu hakkında etiketler |
alma demek dilinde ekrani input inputoutput kodlari kodu nedir okumak output standard standart std yerine |
| Ilk C Programiniz | Önceki | Sonraki | | Karakter Katari Girisi | ||
| |
| Alakalı Diğer Yazılar |