1. OutputStream
sınıf
Kısa bir süre önce giriş akışlarını araştırdık. Çıkış akışları hakkında konuşmanın zamanı geldi.
Sınıf OutputStream
, bayt çıktısını destekleyen tüm sınıflar için üst sınıftır. Bu, kendi başına hiçbir şey yapmayan soyut bir sınıftır, ancak her durum için alt sınıfları vardır.
Kulağa son derece karmaşık geliyor. Daha basit bir şekilde ifade etmek gerekirse, bu sınıf, örneğin karakterler veya diğer veri türleri üzerinde değil, baytlar üzerinde çalışır. Ve soyut olduğu gerçeği, genellikle onu kullanmadığımız, onun soyundan gelen sınıflardan birini kullandığımız anlamına gelir. Örneğin FileOutputStream
ve benzerleri.
Ama sınıfa geri dönelim OutputStream
. Bu sınıf, tüm alt sınıflarının uygulaması gereken yöntemlere sahiptir. İşte ana olanlar:
Yöntemler | Tanım |
---|---|
|
int Akışa bir bayt ( değil) yazar . |
|
Akışa bir dizi bayt yazar |
|
Bir bayt dizisinin bir bölümünü akışa yazar |
|
Tamponda depolanan tüm verileri akışa yazar |
|
Akışı kapatır |
Miras alan bir sınıftan bir nesne oluşturduğunuzda InputStream
, genellikle verilerin okunacağı bir kaynak nesne belirtirsiniz InputStream
. Miras alan bir sınıftan bir nesne oluşturduğunuzda OutputStream
, genellikle verilerin yazılacağı hedef nesneyi veya akışı da belirtirsiniz.
Sınıfın tüm metotlarını kısaca gözden geçirelim OutputStream
:
write(int b)
yöntem
int
Bu yöntem , çıktı akışına bir bayt (bir değil) yazar . Geçirilen değer bir bayta dönüştürülür ve int'nin ilk üç baytı atılır.
write(byte[] buffer)
yöntem
Verilen bayt dizisini çıkış akışına yazar. Bu kadar.
write(byte[] buffer, int offset, int length)
yöntem
Geçirilen bayt dizisinin bir bölümünü çıkış akışına yazar. Ofset değişkeni, dizinin ilk elemanının indeksini gösterir ve length
yazılacak altkümenin uzunluğudur.
flush()
yöntem
Yöntem flush()
, geçerli akışta potansiyel olarak tamponlanmış herhangi bir veriyi hedef akışa yazılmaya zorlamak için kullanılır. Bu, ara belleğe alma ve/veya zincir halinde düzenlenmiş çoklu akış nesneleri kullanıldığında geçerlidir.
close()
yöntem
Yazılmamış verileri hedef nesneye yazar. Bir blok close()
kullanırsanız yöntemin çağrılması gerekmez .try-with-resources
Dosya kopyalama örneği
kod | Not |
---|---|
|
InputStream bir dosyadan okumak için OutputStream bir dosyaya yazmak için İçine verileri okuyacağımız arabellek Akışta veri olduğu sürece verileri arabelleğe oku Verileri arabellekten ikinci akışa yaz |
2. Writer
sınıf
Sınıf Writer
, sınıfla tamamen aynıdır OutputStream
, ancak yine bir fark vardır: char
bayt yerine karakterlerle ( ) çalışır.
Bu soyut bir sınıftır: sınıfın nesnelerini oluşturamazsınız Writer
. Ana hedefi, yüzlerce alt sınıf için ortak bir üst sınıf olmak ve onlara karakter akışlarıyla çalışmak için ortak yöntemler vermektir.
Sınıfın yöntemleri Writer
(ve onun soyundan gelen tüm sınıflar):
Yöntemler | Tanım |
---|---|
|
int Akışa bir karakter (bir değil) yazar . |
|
Akışa bir dizi karakter yazar |
|
Bir karakter dizisinin bir kısmını akışa yazar |
|
Akışa bir dize yazar |
|
Dizinin bir bölümünü akışa yazar |
|
Tamponda depolanan tüm verileri akışa yazar |
|
Akışı kapatır |
Yöntemler, sınıfın yöntemlerine çok benzer OutputStream
, ancak bayt yerine karakterlerle çalışırlar.
Yöntemlerin açıklaması:
write(int b)
yöntem
Bu yöntem, çıktı akışına tek bir karakter ( char
— değil ) yazar. int
Geçirilen değer a'ya dönüştürülür char
ve ilk iki bayt atılır.
write(char[] buffer)
yöntem
Verilen karakter dizisini çıkış akışına yazar.
write(char[] buffer, int offset, int length)
yöntem
Geçirilen karakter dizisinin bir bölümünü çıkış akışına yazar. Değişken offset
, dizinin ilk elemanının indeksini gösterir ve length
yazılacak altkümenin uzunluğudur.
write(String str)
yöntem
Verilen dizeyi çıkış akışına yazar.
write(String str, int offset, int length)
yöntem
Verilen dizgenin bir bölümünü çıkış akımına yazar: dizge bir karakter dizisine dönüştürülür. Değişken offset
, dizinin ilk elemanının indeksini gösterir ve length
yazılacak altkümenin uzunluğudur.
flush()
yöntem
Yöntem flush()
, geçerli akışta potansiyel olarak tamponlanmış herhangi bir veriyi hedef akışa yazılmaya zorlamak için kullanılır. Bu, ara belleğe alma ve/veya zincir halinde düzenlenmiş çoklu akış nesneleri kullanıldığında geçerlidir.
close()
yöntem
Yazılmamış verileri hedef nesneye yazar. Bir blok close()
kullanırsanız yöntemin çağrılması gerekmez .try-with-resources
Bir metin dosyasını kopyalayan bir program örneği:
kod | Not |
---|---|
|
Reader bir dosyadan okumak Writer için bir dosyaya yazmak için İçine verileri okuyacağımız arabellek Akışta veri olduğu sürece verileri bir arabelleğe oku Verileri arabellekten ikinci akışa yaz |
StringWriter
sınıf
Sınıfı devralan başka bir ilginç sınıf daha var Writer
: adı StringWriter
. Değişken bir dize içerir - bir StringBuffer
nesne. Ve nesneye bir şey "yazdığınız" her seferde StringWriter
, metin basitçe dahili arabelleğine eklenir.
Örnek:
kod | Not |
---|---|
|
Bir hedef karakter akışı ( StringWriter ) oluşturulur. Bir dize, içindeki arabelleğe yazılır. StringWriter Bir dize, içindeki arabelleğe yazılır. StringWriter Bir nesnenin içeriğini bir dizeye dönüştürme |
Bu durumda, StringWriter
sınıf aslında sınıfın üzerinde bir sarmalayıcıdır StringBuffer
, ancak StringWriter
sınıf, akış sınıfının soyundan gelir Writer
ve akış nesnelerinin zincirlerinde kullanılabilir. Bu pratikte oldukça kullanışlı bir özelliktir.