API Nedir?
API Nedir?
İşletim sistemlerine duyulan ihtiyaçlardan biri standart olarak her program tarafından yapılması gereken şeyleri ortak bir çatı altında toplamak ve programları sistemde belirli kurallar altında çalışmasını sağlamaktır. İşletim sistemlerinin değerini anlamak için işletim sistemi olmayan bir bilgisayar düşünün.
Yaptığınız programları diske kaydetme ihtiyacınız var. İşletim sisteminiz yoksa programlarınızı diske yazacak ve okuyacak assembly kodları sizin yazmanız gerekecektir. Ve her program diske yazma ve okuma kodlarını içinde bulundurmak zorunda olacaktır. Ayrıca diske yazacağınız programı diskin neresine yazacaksınız. Tabi ki herkes kendi programının başa yazılmasını isteyecektir. Bu da diski paylaşım sorununu çıkaracaktır. Ayrıca yazıcı için de problem vardır. Her yazıcı aynı sistemle çalışmayacağı için programınızda yazdırma işlemleri de varsa belli başlı yazıcı tipleri için gerekli kodları yazmanız gerekecektir. Bu örnekler çoğaltılabilir.
İşte PC’ler ilk çıktığında disk işlemlerini kolaylaştırmak için DOS ta piyasaya çıktı. DOS disk işlemlerini yapmak için yazılım interruptlarını programcıların hizmetine sunmuştu. Diskle ilgili bir işleminiz için INT X’in Y numaralı servisini çağırıyordunuz ve bu işlemleri sizin yerinize DOS yapıyordu. Sistemler geliştikçe bilgisayar değişik alanlara da hitap etmeye başlayınca çok değişik arabirimler de çıktı. DOS’a grafik, yazıcı işlemleri gibi standart işlemler de eklendi ve sistemde bulunan standart donanımların hemen hemen hepsine DOS veya BIOS interruptlarıyla erişebiliyordunuz. Ayrıca DOS programların belleği nasıl kullanacağını da belirliyordu. DOS işletim sistemi olarak kullanıcıya herhangi bir standart arabirim sunmamıştır. Sadece programların sistemdeki standart donanımlara ulaşabilecekleri kodları kullanıcıya sunmuştur. DOS’ta yapılan programların hiçbiri bir birine benzemez. Her program kendi kullanıcı arayüzünü belirlemek zorundadır ve bunun için gerekli kodu kendisi yazmak zorundadır. DOS’ta yapılan programların kullanım ve programlanmasının zorluğu da bir ölçüde buradan kaynaklanır.
DOS’un programlara standart bir arabirim sunmaması, bellek sınırlarının olması gibi sebeplerden dolayı çok çok geç kalmış olsada Windows çıktı. Windows DOS’un sağladığı standart donanıma ulaşma haricinde Ses kartları, Gelişmiş yazıcılar, Scanner’ler gibi donanımların kullanımını da programların kullanımına sunar. Ayrıca programlara standart arabirimleri (Diyalog kutuları, Formlar, Kontroller gibi) kullanma imkanı da sunmuştur. DOS kendi servislerini yazılım interruptlarıyla sunarken Windows API’lerle sunar.
Şimdi şöyle bir şey düşünülebilir. DOS’ta çok program yaptım ama diske birşey yazdırmak için DOS’un interruptlarını kullanmaya hiç ihtiyaç duymadım. Evet eğer assembly program yazmadıysanız bunlara da ihtiyacınız yoktur. Çünkü kullandığınız programlama dili bu işi sizin yerinize yapıyordu. Bu VB’de yaptığınız programlarda da böyledir. API kullanacaksınız diye bir şart yok VB bunları sizin yerinize kullanır. Ancak DOS’taki programlama dillerinde olduğu gibi VB’de de programlama dilinin sunduğu işlemler her zaman işinizi görmeyebilir, bu durumda Windows API’lerini kullanma ihtiyacı duyarsınız.
Basic herhalde bütün zamanların en yavaş programlar üreten dili olma özelliğini kimseye kaptırmak istemiyor. Quick Basicte yaptığınız bir program, aynı işi yapan C ile yapılmış programdan en az 5 kat daha yavaş çalışacaktır. Bu fark GWBasic’te daha da büyüktür. VB’de de durumun iç açıcı olduğunu iddia etmek çok güç. Programlarınızda API kullanmanız bu hız barajlarını aşmanızı sağlayacaktır. Ayrıca VB’nin sunmadığı bazı işlemler için de API kullanmak gerekir. Örneğin sistemdeki boş bellek miktarını verecek herhangi bir komut VB’de bulunmaz bunu da yine API kullanarak öğrenmek zorundasınız.
Windows’un sunduğu bu API’ler gruplandırılarak bir çok DLL ve EXE dosyasına konmuştur. VB’de kullanılan OCX dosyalarında da API’ler bulunabilir. Bu API’lerden birini kullandığınızda API’nin bulunduğu DLL sisteme daha önce yüklenmemişse önce bu DLL yüklenir ve API çalıştırılır.
Programınızda API kullanmak için Declare deyimiyle API’yi tanımlamanız gerekir. Bu tanımdan sonra tanımladığınız API’ye bir fonksiyon veya bir altprogram gibi ulaşabilirsiniz.
VB’de API Tanımı
VB’de API’ler iki şekilde tanımlanabilir. Fonksiyon veya altprogram olarak. Fonksiyon olarak tanımlanan API’lerden geriye bir değer dönerken, altprogram olarak tanımlananlardan bir değer geri dönmez.
Alt program olarak API tanımı:
Private/Public Declare Sub isim Lib “libname” [([parametreler])]
Fonksiyon program olarak API tanımı:
Private/Public Declare Function isim Lib libname [([parametreler])] [As tip]
Burada isim fonksiyonun ismidir ve programda API bu isimle çağrılır. Libname kullanılan kütüphanenin ismi, parametreler; fonksiyona giren parametreler, As tip; fonksiyondan dönen değerin tipidir.
API’nin tanımlanacağı yer formun veya modülün General-Declerations kısmıdır. API’yi bir formun decleration kısmında tanımlarsanız API’yi yalnız o formun altprogramlarından çağırabilirsiniz. Bir modülde tanımlarsanız programınızın her yerinde kullanabilirsiniz.
API’yi doğru olarak tanımladığınız halde VB, ilgili dosyada böyle bir API bulunmadığını söylüyorsa veya API ile aynı isme sahip bir VB komutu var ise bu durumda Alias isimleri kullanmanız gerekir.
Private/Public Declare Function/Sub isim Lib libname Alias “isim” [([parametreler])] [As tip]
API’yi doğru olarak tanımladığınız halde VB, ilgili dosyada böyle bir API bulunmadığını söylüyorsa API isminin sonuna A ekleyerek Alias ismi olarak vermeniz gerekir. Bunun sebebi Windows işletim sisitemi farklı dilleri desteklemektedir. ANSI karakter setini destekleyen ülkler için sonuna A harfi, UniCode veya iki karekter genişliğini kullanan ülke seti için ise sonuna W harfi eklemeniz gerekir.
API tanımı yaparken kullanacağınız tiplerin isimlerini ise C’den VB’ye çevirmeniz gerekir. Genel olarak tip karşılıkları şöyledir.
C | Visual Basic | |
atom | ByVal değişken AS integer | |
bool | ByVal değişken As Long | |
byte | ByVal değişken As Byte | |
char | ByVal değişken As Byte | |
colorref | ByVal değişken As Long | |
dword | ByVal değişken As Long | |
hwnd,hdc,hmenu vb | ByVal değişken As Long | |
int,uint | ByVal değişken As Long | |
long | ByVal değişken As Long | |
lparam | ByVal değişken As Long | |
lpdword | değişken As Long | |
lpint,lpuint | değişken As Long | |
Iprect | değişken As type | |
Ipstr,Ipcstr | ByVal değişken As String | |
Ipvoid | değişken As Any | |
lpword | değişken As Integer | |
lresult | ByVal değişken As Long | |
null | değişken As Any veya ByVal değişken As Long | |
short | ByVal değişken As Integer | |
void | Sub procedure | |
word | ByVal değişken As Integer | |
wparam | ByVal değişken As Long | |
16 bit | ByVal değişken As Integer | |
32 bit | ByVal değişken As Long | |
float | ByVal değişken As Single | |
double | ByVal değişken As Double |
Parametrelerden biri iki farklı tipte değer alabiliyorsa bunu As Any olarak tanımlamanız gerekir. Hangi parametrenin Any olarak tanımlanması gerektiğine ancak dosyadaki bilgileri okuyarak anlayabilirsiniz. Örneğin bir parametre hem string içerebiliyor ve hemde Null içerebiliyorsa bu parametre Any olarak tanımlanmalıdır.
Yaptıkları işlere göre API’lerin bulundukları dosyalar ise şunlardır :
DLL | Fonksiyonları | |
Advapi32.dll | Şifre ve Kayıt dosyası işlemleri gibi gelişmiş bir çok API’ler | |
Comdlg32.dll | Diyalog pencereleri ile ilgili API’ler | |
Gdi32.dll | Grafik API’leri | |
Kernel32.dll | Çekirdek Windows API’leri | |
Lz32.dll | 32 bit skıştırma API’leri | |
Mpr.dll | Multiple Provider Router API’leri | |
Netapi32.dll | 32-bit Network API’leri | |
Shell32.dll | 32-bit Shell API’leri | |
User32.dll | Kullanıcı arabirimi API’leri | |
Version.dll | Versiyon işlemleri API’leri | |
Winmm.dll | Multimedia API’leri | |
Winspool.drv | Print spooler API’leri |