Les Java InputStream
et OutputSteam
sont tous deux des classes abstraites qui sont utilisées pour accéder à l'ensemble de données sous-jacente. Ce sont des API qui définissent les opérations pour des séquences de données spécifiques, implémentées à travers une série d'étapes. InputStream
Réorganisez l'ensemble de données dans un flux ordonné d'octets pour lire les données d'un fichier ou d'un réseau. Renvoie -1 à la fin du flux (Java n'a pas de type de données d'octet non signé). OutputStream
reçoit alors des octets de sortie et les écrit à la cible. Il s'agit de la méthode la plus fondamentale pour rédiger une sortie d'octet unique. Cet article comparera les différences entre ces deux flux et les expliquera en combinaison avec des applications pratiques.
Exemple d'entrée
FileOutputStream fileOut = new FileOutputStream("ARBRDD.txt");
Exemple de sortie
<code>file is successfully updated today!!</code>La différence entre
InputStream
et OutputStream
Fonctionnalités
特性
InputStream
OutputStream
数据读取/写入
使用 read()
、read(byte[])
、read(byte[], int, int)
读取数据
使用 write(int)
、write(byte[])
、write(byte[], int, int)
写入数据
数据流向
数据从源流向应用程序
数据从应用程序流向目标
数据类型
可读取字节
可写入字节、字符或对象(使用子类)
数据连接
可使用 FileInputStream
或 ByteArrayInputStream
连接现有数据
可使用 FileOutputStream
或 ByteArrayOutputStream
连接现有数据
head>
Données lire / écrire
utiliser read ()
, read (byte [])
, read (byte [], int, int)
/ td>
Écrire des données à l'aide de write (int)
, écrire (byte [])
, écrire (byte [], int, int)
Flux de données
Données Flux de la source à l'application
Les données circulent de l'application à la cible
Type de données
Bytes lisibles
Ont-bocals, caractères ou objets (en utilisant des sous-classes)
Connexion de données
Vous pouvez utiliser fileInputStream
ou bytearrayInputStream
pour se connecter aux données existantes
Vous pouvez utiliser fileoutputStream
ou bytearrayoutputStream
pour se connecter aux données existantes
table> comment utiliser
Utilisez les fonctions FileInputStream
et FileOutputStream
.
algorithme
Cet algorithme décrit le flux de travail de la classe Stream. Déclarez et définissez d'abord l'ordre d'insertion (par exemple, en utilisant la classe TIMER). Le résultat d'entrée est ensuite évalué par itération de la traversée de longueur.
- Étape 1 - Démarrez le processus.
- Étape 2 - Déclarez le flux d'entrée et de sortie.
- Étape 3 - Importez des classes intégrées et des fonctions déclarées.
- Étape 4 - Déclarer une classe publique.
- Étape 5 - Définissez la fonction.
- Étape 6 - Effectuez l'opération d'insertion.
- Étape 7 - Déclarez une liste de tableaux et remplissez-la.
- Étape 8 - Déclarez la valeur définie.
- Étape 9 - Imprimez les valeurs de l'ordre de l'insertion.
- Étape 10 - Déclarez une boucle pour itérer le processus.
- Étape 11 - Définissez la valeur de la minuterie.
- Étape 12 - Exécutez le processus et obtenez la valeur de sortie.
- Étape 13 - Terminez le processus.
grammaire
La syntaxe explique comment déclarer un processus comme null pour marquer et sauter le processus booléen. Après cela, nous réinitialiserons le processus pour suivre la valeur de la pile en forçant la classe d'exception.
FileOutputStream fileOut = new FileOutputStream("ARBRDD.txt");
utiliser FileInputStream
et FileOutputStream
Méthodes
Cette méthode utilise les méthodes FileInputStream
et FileOutputStream
pour effectuer du streaming sur la collection.
Exemple
Ce code utilise un fichier texte pour y écrire une chaîne via une fonction Java Stream. Un bloc de capture est déclaré dans ce processus pour gérer l'exception.
<code>file is successfully updated today!!</code>
sortie
public class NewClass {
public static void main(String[] args) throws Exception {
InputStream processARBRDD = null;
try {
processARBRDD = new FileInputStream("FILE_NAME.txt");
// PRINT METHOD
processARBRDD.mark(0);
processARBRDD.skip(1);
// PRINT METHOD
boolean check = processARBRDD.markSupported();
if (processARBRDD.markSupported()) {
processARBRDD.reset();
// PRINT METHODS
} else {
// PRINT METHODS
}
} catch (Exception excpt) {
excpt.printStackTrace();
} finally {
if (processARBRDD != null) {
processARBRDD.close();
}
}
}
}
Conclusion
ByteArray
Le flux est utilisé pour écrire des données sur un tableau d'octets. Dans ce sujet, nous utilisons différentes fonctions de flux pour établir des connexions entre les données et le code.
特性 | InputStream |
OutputStream |
---|---|---|
数据读取/写入 | 使用 read() 、read(byte[]) 、read(byte[], int, int) 读取数据 |
使用 write(int) 、write(byte[]) 、write(byte[], int, int) 写入数据 |
数据流向 | 数据从源流向应用程序 | 数据从应用程序流向目标 |
数据类型 | 可读取字节 | 可写入字节、字符或对象(使用子类) |
数据连接 | 可使用 FileInputStream 或 ByteArrayInputStream 连接现有数据 |
可使用 FileOutputStream 或 ByteArrayOutputStream 连接现有数据 |
read ()
, read (byte [])
, read (byte [], int, int)
/ td>
write (int)
, écrire (byte [])
, écrire (byte [], int, int)
fileInputStream
ou bytearrayInputStream
pour se connecter aux données existantes fileoutputStream
ou bytearrayoutputStream
pour se connecter aux données existantes comment utiliser
Utilisez les fonctions FileInputStream
et FileOutputStream
.
algorithme
Cet algorithme décrit le flux de travail de la classe Stream. Déclarez et définissez d'abord l'ordre d'insertion (par exemple, en utilisant la classe TIMER). Le résultat d'entrée est ensuite évalué par itération de la traversée de longueur.
- Étape 1 - Démarrez le processus.
- Étape 2 - Déclarez le flux d'entrée et de sortie.
- Étape 3 - Importez des classes intégrées et des fonctions déclarées.
- Étape 4 - Déclarer une classe publique.
- Étape 5 - Définissez la fonction.
- Étape 6 - Effectuez l'opération d'insertion.
- Étape 7 - Déclarez une liste de tableaux et remplissez-la.
- Étape 8 - Déclarez la valeur définie.
- Étape 9 - Imprimez les valeurs de l'ordre de l'insertion.
- Étape 10 - Déclarez une boucle pour itérer le processus.
- Étape 11 - Définissez la valeur de la minuterie.
- Étape 12 - Exécutez le processus et obtenez la valeur de sortie.
- Étape 13 - Terminez le processus.
grammaire
La syntaxe explique comment déclarer un processus comme null pour marquer et sauter le processus booléen. Après cela, nous réinitialiserons le processus pour suivre la valeur de la pile en forçant la classe d'exception.
FileOutputStream fileOut = new FileOutputStream("ARBRDD.txt");
utiliser FileInputStream
et FileOutputStream
Méthodes
Cette méthode utilise les méthodes FileInputStream
et FileOutputStream
pour effectuer du streaming sur la collection.
Exemple
Ce code utilise un fichier texte pour y écrire une chaîne via une fonction Java Stream. Un bloc de capture est déclaré dans ce processus pour gérer l'exception.
<code>file is successfully updated today!!</code>
sortie
public class NewClass { public static void main(String[] args) throws Exception { InputStream processARBRDD = null; try { processARBRDD = new FileInputStream("FILE_NAME.txt"); // PRINT METHOD processARBRDD.mark(0); processARBRDD.skip(1); // PRINT METHOD boolean check = processARBRDD.markSupported(); if (processARBRDD.markSupported()) { processARBRDD.reset(); // PRINT METHODS } else { // PRINT METHODS } } catch (Exception excpt) { excpt.printStackTrace(); } finally { if (processARBRDD != null) { processARBRDD.close(); } } } }
Conclusion
ByteArray
Le flux est utilisé pour écrire des données sur un tableau d'octets. Dans ce sujet, nous utilisons différentes fonctions de flux pour établir des connexions entre les données et le code.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

JavadevelopmentSnotentivelyPlatform-indépendant de la duetoseveralfactors.1) jvmvariationSAffecctPerformanceAndbehavioracrossdifferentos.2) nativelibrarysviajniintroduceplatform-specificiss.3) goypathesystempropertiesdifferbetweenweenplateforms.4) goypathesmepropertiesdifferbetweenweenplateforms.4) guiaplicapropertiesdifferbetweenweenplateforms.4) guiaplicapropertiesdifferbetweenweenplateforms.4) guiaplicaaPropertiesdifferbetweenweenplateforms.4) GuiaplicaAplicaAplisses.

Java Code aura des différences de performances lors de l'exécution sur différentes plates-formes. 1) Les stratégies de mise en œuvre et d'optimisation de JVM sont différentes, comme OracleJDK et OpenJDK. 2) Les caractéristiques du système d'exploitation, telles que la gestion de la mémoire et la planification des threads, affecteront également les performances. 3) Les performances peuvent être améliorées en sélectionnant le JVM approprié, en ajustant les paramètres JVM et l'optimisation du code.

Java'splatformindependensencehaslimitations incluant la performance de la tête, les versions de verso, les défis avec l'intégration de la plate-forme spécifique et lajvminstallation / maintenance.

Platform IndependeneNallowsProgramStorUnonanyPlatformWithoutModification, whilecross-plateformDevelopmentRequireStomePlatFatFor-SpecificAdjustments.

JitCompilationInjavaenHancesPerformance WhileSainingPlatForceLindependence.1) itdynynamicalTranslatesByTecodeIntOnAativemArnEcodeATrutime, OptimizingFrement UsedCode.2) thejvmremainsplatform-independent, permettant à la vigueur.

Javaispopularforcross-plateformdesktopapplicationsDuetoit "writeOnce, runanywhere" philosophy.1) iTUSESBYTECODETHATrunSonanyjvm-equipppatform.2) bibliothèqueslikeswingandjavafxhelpcreenative-lookporport

Les raisons de l'écriture du code spécifique à la plate-forme en Java incluent l'accès à des fonctionnalités spécifiques du système d'exploitation, l'interaction avec le matériel spécifique et l'optimisation des performances. 1) Utilisez JNA ou JNI pour accéder au registre Windows; 2) interagir avec les pilotes matériels spécifiques à Linux via JNI; 3) Utilisez du métal pour optimiser les performances de jeu sur macOS via JNI. Néanmoins, la rédaction du code spécifique à la plate-forme peut affecter la portabilité du code, augmenter la complexité et potentiellement poser des risques de performances et de sécurité.

Java améliorera encore l'indépendance des plates-formes grâce aux applications natives dans le cloud, au déploiement multi-plate-forme et à l'interopérabilité inter-language. 1) Les applications natives Cloud utiliseront Graalvm et Quarkus pour augmenter la vitesse de démarrage. 2) Java sera étendu aux appareils intégrés, aux appareils mobiles et aux ordinateurs quantiques. 3) Grâce à GraalVM, Java s'intègre de manière transparente à des langages tels que Python et JavaScript pour améliorer l'interopérabilité transversale.


Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

Adaptateur de serveur SAP NetWeaver pour Eclipse
Intégrez Eclipse au serveur d'applications SAP NetWeaver.

ZendStudio 13.5.1 Mac
Puissant environnement de développement intégré PHP

MantisBT
Mantis est un outil Web de suivi des défauts facile à déployer, conçu pour faciliter le suivi des défauts des produits. Cela nécessite PHP, MySQL et un serveur Web. Découvrez nos services de démonstration et d'hébergement.

PhpStorm version Mac
Le dernier (2018.2.1) outil de développement intégré PHP professionnel
