Search code examples
c#usingmemorystream

Why do I get the an out of memory error when I use using?


I have the following method, to convert a BitmapImage to a System.Drawing.Bitmap:

public static Bitmap BitmapImageToBitmap(BitmapImage bitmapImage)
{
    Bitmap bitmap;

    using (var ms = new MemoryStream())
    {
        var encoder = new JpegBitmapEncoder();
        encoder.Frames.Add(BitmapFrame.Create(bitmapImage));
        encoder.Save(ms);

        bitmap = new Bitmap(ms);
    }

    return bitmap;
}

Whenever I try and use the returned Bitmap object, I get the following error:

OutOfMemoryException occured - Out of memory.

However, whenever I replace the code with this:

public static Bitmap BitmapImageToBitmap(BitmapImage bitmapImage)
{
    var ms = new MemoryStream();

    var encoder = new JpegBitmapEncoder();
    encoder.Frames.Add(BitmapFrame.Create(bitmapImage));

    encoder.Save(ms);

    return new Bitmap(ms);
}

This works fine. However, I am pretty sure that I am supposed to use using as the MemoryStream object implements IDisposable. What's going on here?


Solution

  • Bitmap's constructor Bitmap Constructor (Stream) claims that

    You must keep the stream open for the lifetime of the Bitmap.

    In your case, when you're using using statement, stream (being Disposable) automatically disposed, so your Bitmap object becomes invalid. It's not about that you allocate too much memory, but about that bitmap point to -something that no longer exists.