1. OutputStreamsı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 FileOutputStreamve 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 |
|---|---|
|
intAkış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
intBu 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 lengthyazı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 |
|---|---|
|
InputStreambir dosyadan okumak için OutputStreambir 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. Writersınıf
Sınıf Writer, sınıfla tamamen aynıdır OutputStream, ancak yine bir fark vardır: charbayt 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 |
|---|---|
|
intAkış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. intGeçirilen değer a'ya dönüştürülür charve 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 lengthyazı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 lengthyazı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 |
|---|---|
|
Readerbir dosyadan okumak Writeriç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 |
StringWritersı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 StringBuffernesne. 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. StringWriterBir dize, içindeki arabelleğe yazılır. StringWriterBir nesnenin içeriğini bir dizeye dönüştürme |
Bu durumda, StringWritersınıf aslında sınıfın üzerinde bir sarmalayıcıdır StringBuffer, ancak StringWritersınıf, akış sınıfının soyundan gelir Writerve akış nesnelerinin zincirlerinde kullanılabilir. Bu pratikte oldukça kullanışlı bir özelliktir.
GO TO FULL VERSION