Résolution des problèmes de verrouillage de fichiers lors de la mise à jour des images PictureBox
La mise à jour de la propriété Image d'une PictureBox avec un nouveau Bitmap peut parfois déclencher une exception, laissant le fichier image verrouillé. En effet, Bitmap conserve une référence au fichier source.
Solution : chargement efficace des images sans verrouillage de fichiers
La solution consiste à charger l'image sans créer de verrou de fichier. Cette méthode est très efficace :
<code class="language-csharp">public static Image FromFile(string path) { byte[] bytes = File.ReadAllBytes(path); using (MemoryStream ms = new MemoryStream(bytes)) { return Image.FromStream(ms); } }</code>
Ce code lit l'image dans un tableau d'octets, puis la diffuse dans un objet Image, évitant ainsi le verrouillage du fichier. L’image peut ensuite être attribuée en toute sécurité à la PictureBox.
Référence de performances
Une comparaison des performances avec une méthode de copie Bitmap a révélé que cette approche par tableau d'octets est considérablement plus rapide (environ 0,26 ms par image contre 0,50 ms pour la méthode de copie).
Récupération d'un objet Bitmap
Si vous avez besoin d'un objet Bitmap spécifiquement, une légère modification suffit :
<code class="language-csharp">return (Bitmap)Image.FromStream(ms);</code>
Cela garantit que l'objet renvoyé est de type Bitmap.
Ces méthodes fournissent une solution fiable et performante pour mettre à jour les images PictureBox, empêchant le verrouillage des fichiers et améliorant l'efficacité des applications.
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!