Can I do this using using var
:
await foreach (var response in _container.GetItemQueryStreamIterator(query))
{
using var safeResponse = response;
//use the safeResponse
}
or should I do this:
await foreach (var response in _container.GetItemQueryStreamIterator(query))
{
try {
//use response
} finally {
response?.Dispose();
}
}
or can I just go without disposing because the iterator is an IAsyncDisposable
and the await foreach
will do it for me?
await foreach (var response in _container.GetItemQueryStreamIterator(query))
{
//use the response
}
Given an
IEnumerable<IDisposable>
(with or withoutAsync
in it), there is no rules on who should dispose the elements. And therefor, (and hopefully) enumerating it will not dispose it's element.Disposing the elements is your responsibility.
In your question you want to dispose them will iterating, so option 3 is not possible, you have to dispose them by yourself.
Option 1 and 2 are equivalent but both are smelly.
You may write:
Sadly I didn't see any better solution. And it looks like you have to be careful if you work with ValueType. Maybe we should ask for something like this:
Edit of course somebody already ask for it.