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

Matrix ve Felsefe

FZ

Sizin de kafanız Keanu Revees gibi Matrix'ten sonra karıştıysa bu kitap kesinlikle sizin için yazılmış. Eğer film kafanızı karıştırmadıysa, hemen bir doktora görünün. Matrix'i henüz seyretmediyseniz, o zaman bu kitabı mutlaka okumalısınız. Böylece bu filmin insanlar için neden o kadar önemli olduğunu bulursunuz.

Erciyes Linux Dergisi 3. Sayısı

anonim

Erciyes Üniversitesi Linux Topluluğu Sürekli yayını olan "Erciyes Linux Dergisi", Mayıs-Haziran 3.sayısı ile karşımızda...

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ı.

Matematik Dünyası dergisi

anonim

Sayın Meslektaşlarım,

Türk Matematik Derneği’nin on iki yıldan beri çıkarmakta olduğu Matematik Dünyası dergisinin tüm sorumluluğunu 2003 başından itibaren üstlendim. Dergi tepeden tırnağa değişti. Diliyle, biçemiyle, biçimiyle, konularıyla, derinliğiyle, her şeyiyle son derece heyecanlı ve albenili bir dergi oldu. Ilk iki sayımız çıktı ve çok beğeni topladı, çok övgü aldı. Üçüncü sayımız da pek yakında çıkacak.

Okur kitlemizi lise ve üniversite öğrencileri olarak belirledik. Ancak matematiğin evrenselliği sayesinde, profesyonel matematikçilerin de ilgiyle okuduğu bir dergi ortaya çıktı.

Kısıt Koşul Programlama

FZ

Roman Barták'ın "On-line Guide to Constraint Programming" (Kısıt Koşul Programlamaya Giriş) kılavuzu farklı bir yazılım geliştirme paradigması için öenmli bir kılavuz niteliğinde.

Kısıt koşul programlama, kabaca istenen çözümün sağlaması gereken şartların (kısıt koşulların) sunulduğu ve çözümün adım adım tarif edilmediği programlama şekli olarak tanımlanabilir.

Kısıt koşul programlama gitgide popülaritesini artırmaya başladı, Mozart Programming System gibi somut uygulamalar pek çok problemin çözümünde kullanılıyor. NP-zor problemler, yapay zekâ, mantık, elektronik, bilgisayar grafikleri gibi konularda çalışan yazılımcıların kısıt koşul programlama konusunda bilgi sahibi olmalarında fayda var.

Kaynak: Computer Science Daily News