Haftalık C++ 15 – Girdi/Çıktı Manipülatörleri

Programlarımızda, özellikle küçük olanlarda ya da bazı değerleri hızlıca görüntülemek için, en sık kullandığımız yöntemlerden birisi de standart çıktıya bir şeyler basmaktır.
Bunun için de kullanılan en yaygın yöntem, C++ için, std::cout‘tır muhtemelen. Peki bu kardeşimizin kabiliyetlerine ne kadar vakıfız? İşte bu yazımda bu kardeşimize ilişkin yetenekler ile sizleri buluşturacağım.
Öncelikli olarak standart çıktıya bastıklarınızı kontrol etmenize yarayan yapılara “I/O manipulator” denilmekte, biz bunlara Girdi/Çıktı Manipülatörleri diyeceğiz. Bunları kullanabilmek için “#include <iomanip>” başlık dosyasını kodunuzun içerisine eklememiz gerekiyor. Bu manipülatör’lerin çoğu aslında bir fonksiyon ve özel olarak <<, >> ile birlikte kullanmak üzere tasarlanmıştır, aynı zamanda fonksiyon gibi de çağırabilirsiniz (dikkatli okuyucularım, çoğu dediğimi fark etmişlerdir, çünkü setw, setprecision, setbase, setfill, resetiosflags, setiosflags bu kullanımın dışında). Hemen bir örneğe bakalım:

aynı çıktıyı verir.

Şimdi gelelim önemli manipülatörlere. Diğer yazılarımda olduğu gibi bana göre en önemli olanları, kalem kalem, sıralamaya çalışacağım. Tam liste için kaynaklar kısmındaki sayfalara başvurabilirsiniz.

  • boolalpha, noboolalpha:
    • Boolean değerlerin metinsel/nümerik gösterimi için kullanılır. Varsayılan nümerik (noboolalpha) gösterim aktiftir, true değerler 1 ve false değerler 0 olarak bastırılır. boolalpha ile birlikte bu değerler sırası ile “true ve “false” olarak bastırılır.
  • showbase, noshowbase:
    • showbase çağrıldığı durumda 8 düzene göre olan sayılar başların O, 16 lık düzene göre olanlar 0x olarak gösterilir.
  • showpoint, noshowpoint:
    • showpoint kullanıldığı zaman, ondalık kısımlar her zaman gösterilir. Varsayılan olarak tam sayıya yuvarlanır.
  • showpos, noshowpos:
    • showpos ile birlikte, pozitif sayıların önünde ek olarak +  gösterilir. Varsayılan olarak gösterilmez.
  • hexfloat, fixed scientific, defaultfloat:
    • İsimlerinden de anlayacağınız üzere bu fonksiyonlar da, ondalık sayıların nasıl gösterileceğini belirliyor. Ayrıca, girdi olarak verilen değerleri de buna göre ayıklar. Bunları uzun uzadıya anlatmaktansa, sanırım örnek vermek daha iyi olacak.
  • setprecision(n):
    • Ondalık bir sayı gösterildiği durumda, noktadan sonra gösterilecek rakam adetini belirler. Varsayılan adet 6’dır.
  • setbase(n):
    • Girdi ve çıktı için kullanılan sayı sistemini belirler. 8, 10, 16 ve 0 alabilir. 0 çıktı için ondalık gösterim anlamına gelse de girdi için girilen sayıdan sayı sistemini belirle anlamına gelir.dec, hex, octTam sayılar için kullanılan sayı sistemini belirler. setbase(10), setbase(16) ve setbase(8) ile de aynı sonucu alabilirsiniz.
  • ws:
    • İlk boşluk olmayan karakteri görene kadar olan boşluk karakterlerini atar.
  • ends:
    • Çıktıya ‘\0’ ekler.
  • flush:
    • Çıktıya yığılan karakterleri bastırmak üzere gönderir.
  • endl:
    • Çıktıya  ‘\n’ ekler ve bastırmak üzere gönderir.
  • setiosflags(n)/resetiosflags(n):
    • Verilen std::ios sabitlerini atar veya sıfırlar.
  • setw(n):
    • Bir sonraki çıktı için tanımlanan genişliği belirler. Burada eğer bu alanda boşluk kalır ise setfill ile belirlenmiş olan karakter ile doldurulur.
  • setfill(c):
    • Boşlukları doldurmak için kullanılacak olan karakteri belirler. Buradaki boşluklardan kasıt, setw ile tanımlanan genişlikten daha az uzunlukta bir karakter gösterilmesinde durumunda kalan boşluklardır. Varsayılan olarak boşluk karakteri kullanılır.
  • internal, left, right:
    • Boşluk için belirlenmiş karakterlerin nereye yerleştirileceğini belirler. left ve right seçeneği her çıktı için kullanılabilecekken, internal sadece tam, ondalık sayı ve parasal gösterimler için kullanılır.

    •  

Evet arkadaşlar, artık uygulamalarınızda konsolu, standart çıktıyı, istediğiniz gibi kullanabilirsiniz 🙂

Bir sonraki yazımda buluşmak dileğiyle.

Kaynaklar:

Bir cevap yazın

E-posta hesabınız yayımlanmayacak. Gerekli alanlar * ile işaretlenmişlerdir

This site uses Akismet to reduce spam. Learn how your comment data is processed.