Bir programlama dilini bilme ölçüsü nedir ?

0
anonim
LKD listelerinde bir süredir devam etmekte olan bir konu başlığı bu.

Tartışmanın bir yerinde bir arkadaş "Bir programlama dilini bilmek için hiç bir başvuru kaynağı kullanmaksızın program yazılabilmeli " dedi.

Bunun üzerine eski FM'cilerden, Uludag projesi COMAR projesi baş programcısı Serdar Köylü yeni başlayanlar için kılavuz olabilecek nitelikte, makale tadında bir yanıt gönderdi.

Ben de listelerde yazılan herşeyin gayet GPL olduğunu düşünerek kendisine sormadan buraya haber olarak geçiyorum :)
Selamlar...

bir programlama dilini "tam olarak biliyorum" demek için, o programlama dili üzerinde hiçbir kaynaktan (uç kaynaklar dışında) yararlanmadan program geliştirebiliyor olmanız gerekir.


!?...

Bu ezbercilik olup, cogu zaman berbat program yazmanın en iyi yolu olur. 20 Yıl önce bizde böyle yapardık. Ama son 15 yıldır kullandığım C için örneğin, hala "fd = open(...)" yazarken (mesela) mutlaka man dosyasını açıp bakmayı ihmal etmem.. Herhalde ortalama günde 25-30 defaya filan tekabül eder bu..

Kısacası, hıfzı beşer nisyanla maluldur. Önemli olan herşeyi bilmeye, ezberlemeye çalışmak değil, anlamaya odaklanmak, ezber olacak bilgiyi ise nerde bulacağını bilmektir.

Programlama dilini iyi biliyorum diyebilmek için bilinmesi gerekenler bence şunlardır (en azından ilgilenilen mimariler üzerinde):

1. Bellek yönetimini bilmek. Sayılar, arraylar, nesneler vs. nasıl, nerde saklanıyor?
2. Fonksiyon çağrıları nasıl yapılıyor? Stack üzerinden mi? Byval'mı, Reference'mı kullanıyor vs.?
3. Temel komut setini iyi kavramak. Bu komut seti örneğin C için:

if/else/elseif, switch, while, for, break/continue, return olacaktır.

Elbette 1. Maddeye istinaden int, float, struct gibi veritiplerini de bilmek gerekir. "int x" ile "static int x" arasındaki farkı, bu "x" in stack/data/bss vs. nerede tutulduğunu bilmek elzemdir. C özelinde, #define gibi preprocessor komutlarını da bilmek gerekir elbet.

Peki ya printf() yada mmap()? Bunlar dışarıdan referanslardır. Bunların iyi bilinmesi değil, iyi anlaşılması, kodlama boyunca da manuallerinin el altında tutulması gerekir. Kendi adıma hala printf için ? ve %? olaylarını bilmem, ki 15 yıla yakın süredir bunları kullanırım. Bunları ezberlemeye çalışmak hamallıktır, gereksiz kafa şişirmektir.

Aslen, bu fonksiyonlar dilin değil, işletim sisteminin bir parçasıdır. Diller bunları tarif eder, işletim sistemi yerine getirir. Bir diğer husus ise, "Programlama" kavramının "Programlama Dili" kavramından ayrı olduğudur. Diller bilinen direktifleri, işletim sistemine ne istediğinizi söylemeyi sağlayan fonksiyon setlerini ve işletim sistemine erişim hizmetini sağlarlar. Bunları ne yapacağınız sizin sorununuzdur. Elinizde olanda aslen bu kadarıdır. Grid, textbox, veritabanı vs. olayı nedir, nasıl kullanılır kavramları aslolarak programlama konusunun bir parçasıdır. Eğer programlama bilginiz varsa bu olayları herhangi bir dille kolayca aşabilirsiniz.

Programlama, olayın özüdür. Herhangi bir dilde yapılabilir. Eğer programl ama kavramını özümsemişseniz, herhangi bir dil kullanarak bunu yerine getirebilirsiniz. Hatta, bu bunlarla olmaz diyerek kendi dilinizi yazıverirsiniz. Bu şunu demeye çalışıyor: "Dil öğrenmek değil, programlama öğrenmek aslolandır.."

Saygı ve sevgiler...

Görüşler

0
bm
Buyuk olcude katiliyorum, o bilme tarifi dogru bir tarif degil. Kitaba yahut kaynaga bakmadan ben de hicbirsey yapamam, yapmaya kalkarsam olur belki ama rahat hissetmem kendimi. Yazilisi olan bir seyi deneysel olarak ve kotu bir surpriz seklinde bulma ihtimali de var, zamana yazik. Satiyorsak, ne bicim soforum diye tek gozu kapayip otobus kullanmaya benziyori bu. Geregi yokken isimizi riske sokmak yani.

Son paragrafi tam anlamadim. Malumu ilam mi, daha derin bir bilgelik mi var yoksa cok kabiliyetli oldugunu tahmin ettigim birinin herkesi kendi gibi zannetmesinin tezahuru mu bilmiyorum. Benim isime gelen 'bilen her dilde yapar' yerine 'bilmeyene dil secimi yardimci olmaz' demek kabaca. Ilkinden daha zayif bir ifade tabi. (ikisi de excel'le her gun program yazanlari kapsamiyor tabi, o ayri).
0
Nightwalker
Son paragrafi tam anlamadim. Malumu ilam mi, daha derin bir bilgelik mi var yoksa cok kabiliyetli oldugunu tahmin ettigim birinin herkesi kendi gibi zannetmesinin tezahuru mu bilmiyorum. Benim isime gelen 'bilen her dilde yapar' yerine 'bilmeyene dil secimi yardimci olmaz' demek kabaca. Ilkinden daha zayif bir ifade tabi. (ikisi de excel'le her gun program yazanlari kapsamiyor tabi, o ayri).


Söz konusu yanıtın yeni başlayanlara yol gösterici nitelikte olduğunu düşünürsek, malumu ilan gerekli olabiliyor.
0
roktas
| ... malumu ilan gerekli olabiliyor.

Affınıza mağruren bu dil yâresine işaret etmek isterim. Doğrusu bm'nin yazdığı gibi, yani "ilâm etmek" = "ilm'edilir" ~= "bilinir" kılmak. (Mahkemelerde resmî hüküm duyurularında kullanılır.) Lâtif bir terkiptir. Çünkü "ma'lûm" ve "ilâm" aynı kökten gelir, yani "zaten bilineni bilinir kılmak" :-) Neyse, kaldığımız yerden devam edebiliriz...

P.S. Yoksa taht-eş şuurda "Bilişsel Bilimler Kılavuzu"na yapılan me'yus bir atak mı oldu bu?
0
bm
Bu vesileyle FM'nin herhalde en cok harf hatasi yapan uyesi olarak dusundugumu dogru yazdigim nadir anlarin farkedilmesine ragmen yanlislarim affedildigi icin butun camiaya -- yine e yerine a basmayayim aman diyerek -- tesekkur ederim. (Mozilla'daki metin alanlanlarini gnuclientla emacsa baglayip. orada da o HMM'li deasciifier'in biraz daha bana uyanini calistirma projem ZS-3765 koduyla proje sirasina sokuldu.)
0
bio
ZS-3765

Bu ZS Zihni Sinir'den geliyorsa, proje degil de proce olmasi gerekmez miydi :-)
0
Soulblighter
Bence bir programlama dilini bilmekten çok programlama mantığını bilmek önemlidir. Genel olarak bakıldığında birçok programlama dili birbirine yakındır. Program yazma mantığını öğrenmişseniz bir çok dilde rahatlıkla program yazabilirsiniz. Kod ezberlemek bana göre hamallıktır.

Örneğin program yazarken belli bir durumda dizi kullanmanın veya hangi durumlarda işaretçi kullanmanın daha avantajlı olacağını bilmek gerekir. Nasıl kullanıldığına ise açıp yardımından veya kod referansından bakabilirsiniz. Zaten kod referans belgelerinin amacı da budur.

Kısacası ne yapacağınızı bilmeniz gerekir. Nasıl yapacağınızı ise belgelerden öğrenebilirsiniz...

Yani bence böyle :)
0
jai
Anneannemin 1 metre uzunluğunda bir değneği vardır; yürürken ondan destek alır. Sıradan bir tahta parçası. Anneanneme güzel bir baston verseniz kullanmaz. Çünkü o yıllarca elindeki değneğe alışmıştır, değneğin dengesine hakimdir. Tüm özelliklerini bilir, tanır (kimbilir, belki değnek de anneannemi tanıyordur). Anneanneme "yürümeyi anlat" deseniz, size değnekten de bahseder.
Programlama kavramından bahsederken bizim de elimizdeki değneğe bağlı olmak zorunda olduğumuzu düşünüyorum. Çünkü bir programcı programlama kavramını elindeki aracın biçimiyle tanıyacaktır. Birinin elinde C, birinin elinde Java olan iki programcıya "programlamayı anlat" derseniz eminim ki daha 2.dakikadan itibaren biri C'nin diğeri Java'nın felsefelerini anlatmaya başlayacaklardır. Programlama dillerinin birer çift göze benzediklerini düşünürüm ben.
Serdar Köylü'nün fopen, printf vs. ile ilgili söylediklerine katılmakla birlikte, konunun başlığındaki soruya şöyle cevap vermeyi tercih ederim:
Bir programlama dilini bilme ölçüsü, o programlama dilinin felsefesini tanıma ölçüsüdür.
Ezberle ilgisi yoktur. En temel görülen fonksiyonların kullanımını görmek için her defasında kılavuzlara bakmak ayıp da değildir, günah da. Hatta bakmayan ayıp eder, günaha girer...
0
GaripFakir
Hazir ölçülerden konu açılmışken, Peki bir işletim sistemini bilmenin ölçüsü nedir? özgür yazilim çerçevesinde konuşacak olursak
Mesela ben Debian ya da slackware'i biliyorum demenin ölçüsü ne olur?

0
FZ
Bir Lisp programcısı için bu ölçü "o dil için derleyici yazabilmek" idi. Adam Lisp'i bir Lisp derleyicisi yazarak öğrendiğini ve artık kendini "Lisp bilen insan" olarak kabul ettiğini söylüyordu (Franz için mi çalışmaya başlamıştı yoksa LispWorks'ü üreten firma için mi, şimdi anımsayamadım).

Dokümantasyon meselesine gelince, orada da ölçü herhalde aradığının o dokümantasyonun neresinde olduğunu kolayca bulabilmek olsa gerek. Bir sayfada konuya dair 15 referans olabilir ve siz bunlardan 2 tanesini nokta vuruşu yapıp yakalıyor, diğerlerinin hedefinizle doğrudan ilgisini olmadığını kestirebiliyorsanız zaten kullandığınız ortama dair epey deneyiminiz var demektir. Elbette ki dokümantasyon kullanmamak buradaki diğer deneyimli yazılımcıların dediği gibi çok saçma bir şey, fotografik hafıza sahibi olmamak garip bir şey değil, bilakis fotografik hafıza sahibi olmak yani bir kez gördüğü bir şeyi, bir metni tüm detayları ile günler sonra hatırlayabilmek çok çok ender rastlanan bir beyin özelliği.

Bir de dilin kendisi dışında kullanılan araç da önemli olabiliyor, onda ustalaşmak bambaşka bir şey olabiliyor. gcc derleyicisinin milyar tane parametresinin hangilerini bir araya getirsek optimize program çıkar hadi değişik değişik parametre setleri deneyip sonuçlara bakan ve optimum seti bulmaya çalışan genetik algoritmalara (!) dayanan programlar yazalım diyen, bu tür araştırma yapan bilgisayarcılar var. Görülen o ki artık gcc'ye optimize program ürettirecek parametre setini bulma işi insanları zorlamaya başlayıp yapay zekâ alanına girmeye başlamış [1, 2]. Bu, tabii dilin kendisinden çok farklı bir konu ama günümüzde artık kullanılan araçlardan bağımsız olarak düşünmek de zor olsa gerek!

1- http://liberty.princeton.edu/Publications/jilp_ose.pdf

2- http://www.cs.colostate.edu/~whitley/CS640/metaopt-pldi03.pdf

0
bm
Bir Lisp programcısı için bu ölçü "o dil için derleyici yazabilmek" idi.

Duane Rettig olsa gerek. Franz'da calisir.

http://alu.cliki.net/Duane%20Rettig's%20Road%20To%20Lisp
0
paprika
bir programlama dilini bilmenin ölçüsü herhalde, belli programlama konseptlerini özümsemekle ilgili birşeydir. diyelim ki, o çok eski basic'ten bu yana kod yazıyorsanız, ve eski alışkanlıklarınız dolayısıyla, oop'yi kullanmakta çekingen davranıyorsanız siz, c++'ı, php'yi vs. bilmiyorsunuz demektir.

daha kısa ve anlamlı bir ifadeyle, bana göre, bir kodlama dilini bilmek demek, onu "verimli" bir biçimde kullanabilmek demektir. elbette bu demek değil ki, her ifadeyi, her operatörü, her naneyi ezberden kodlamanız gerekiyor. hayır. ama, x işinin "nasıl" yapılacabileceğini sezebilmeniz ve eksik ya da yanlış bir kod yazdığınızda bunu anlayabilmeniz gerekir. örneğin, php için (dil mi tartışmasına girmeden) gerekmeyen yerde çift tırnak kullanmamak php'yi bildiğinizin göstergesidir.
0
Geryon
önce printf'in bir komut olmadığı ve dolayısla C dilininde bir parçası olmadığı konusunda anlaşalım.
eğer printf bir C komutu ise KiQueryIOMap'inde bir C komutu olması gerekir. ObDereferenceObject'inde...

zaten C dilinde komut olmadığı(~) gerçeğini görürsek, C dilinin öğrenmenin 10 dakika alacağını görürüz.

Fakat çoğu zaman insalar PC'i programlamayı bilmekle, kullandıkları dili bilmeyi karıştırıyorlar. "Çok iyi C bilmek" ne anlama gelir ? basitce hiçbir anlama gelmez. Çünkü siz "Çok iyi C bilerek" konsola "Hello World !" bile yazdıramazsınız. Sizin diğer standartları bilmeniz gerekir.

Şimdi kaç kişi Win API'lerin hepsini ezbere biliyor ?
win api'lere ezberlemektense windows'un çalışma mekanizmasını bilirseniz Win32SDK ile tüm api'leri kullanırsız...


Görüş belirtmek için giriş yapın...

İlgili Yazılar

GNU/Linux dergisi Penguence'nin 2. sayısı çıkıyor...

FZ

Daha önce yine FM'de duyurduğumuz Penguence dergisinin ikinci sayısı (beta) yayınlandı. Dergiye web tarayıcı ile erişmek mümkün. Henüz PDF hali tam hazırlanmamış olmakla birlikte çalışmaları devam ediyor.

Bu sayıdaki konu başlıklarından bir kaçı:

  • OpenOffice.org 2.0'a doğru - Rıdvan Can
  • Ses ve Müzik - Bülent Bolat
  • Aynı dili konuşuyor muyuz? - Yasin Kokarca
  • Açık Anahtarlı Kriptografi - A. Murat Eren
  • Kitap Eleştirisi : Hackers - Sıradışı Bir Dönemin Sıradışı Hikayesi - Ergin Sevinç
  • Oyun Köşesi : Pathological - Doruk Fisek
  • Çekirdek Derlemekten Korkmayın - Murat Koç
  • Kablosuz LAN Protokolleri - Mustafa Şahin
  • Debian Sosyal Sözleşmesi (Çeviri) - Debian Türk Grubu

Visual Studio Zihninizi Çürütür Mü?

FZ

Yaklaşık 30 yıldır program yazan ve Microsoft Windows programlama kitapları ile saygı duyulan isimler arasında yer alan Charles Petzold'un son makalelerinden Does Visual Studio Rot the Mind? Ruminations on the Psychology and Aesthetics of Coding son zamanlarda okuduğum en güzel yazılardan biri.

Petzold, kullanılan araçların insan düşüncesini inceden inceye nasıl şekillendirdiğine dair mükemmel örnekler vermekle kalmıyor, aynı zamanda konuyu tarihsel bir bakışla da değerlendirip çarpıcı tespitlerde bulunuyor. Sadece Microsoft kullananların, sadece C++ ya da C# kodlayanların değil, GNU/Linux, Java ve VS.NET haricinde IDEler kullananların da okumasında fayda olan bir yazı.

Dopdolu ve Türkçe GNU/Linux Dergisi

FZ

LinuxFocus'un ilk sayısı Kasım 1997´de çıktı. LinuxFocus, İngilizce konuşulmayan ülkerdeki Linux hayranlarının elinde, Linux ile ilgili yazılı kaynakların ve onlar için desteğinin pek olmadığının anlaşılması üzere, Miguel Angel Sepulveda ve arkadaşları tarafından başlatılmıştır.

Derginin Kasım -Aralık 2003 sayısındaki konulardan birkaç örnek vermek gerekirse: GIMP: Kendi fırçalarınızı oluşturun, Blender ile 3D: Bir oda dolusu oyuncak, Çokluişlem programlama - Mesaj kuyrukları (3), Linux ile sıcaklık izleme

Open Source Development with CVS, 3rd Edition

anonim

CVs konusundaki bir soruma yanıt ararken rastladım bu kitaba. Benim gibi CVS ye yeni başlayanlar için herşeyi sıfırdan alarak hayat kurtaran bir kitap. Karl Fogel ve Moshe Bar ın yazdığı bu kitabı CVS kurması yönetmesi veya kullanması gereken herkese tavsiye ederim.

Ah.. En iyi kısmı yazmayı neredeyse unutuyordum. Kitabı bu adresten ücretsiz olarak indirebilirsiniz.

Erciyes Üniversitesi Linux Topluluğu GNU/Linux Dergisi Çıkardı

anonim

Bilişim Kulübü altında faaliyet gösteren Erciyes Üniversitesi Linux Topluluğu (EULT) 2007 yılında kuruldu. Açık kaynak kodlu yazılıma katkıda bulunmak, GNU/Linux'a yeni başlayanlara rehberlik etmek amacıyla yola çıkan topluluk 2008 Ocak ayı itibarı ile e-dergisinin ilk sayısını yayınladı.

Dergiye http://universitem.erciyes.edu.tr/eult_e_dergi_1.pdf adresinden ulaşabilirsiniz.