IFragmentCapableXmlDictionaryWriter.WriteFragment Метод

Определение

Записывает фрагмент XML в основной поток модуля записи.

public:
 void WriteFragment(cli::array <System::Byte> ^ buffer, int offset, int count);
public void WriteFragment (byte[] buffer, int offset, int count);
abstract member WriteFragment : byte[] * int * int -> unit
Public Sub WriteFragment (buffer As Byte(), offset As Integer, count As Integer)

Параметры

buffer
Byte[]

Буфер для записи.

offset
Int32

Начальное положение для записи в параметре buffer.

count
Int32

Число байтов для записи в объект buffer.

Примеры

MemoryStream stream = new MemoryStream();  
MemoryStream fragmentStream = new MemoryStream();  
XmlDictionaryWriter writer = XmlDictionaryWriter.CreateTextWriter(stream);  
IXmlFragmentCapableXmlDictionaryWriter fragmentWriter = writer as IXmlFragmentCapableXmlDictionaryWriter;  
if (fragmentWriter == null || !fragmentWriter.CanFragment)  
{  
Console.WriteLine("This writer doesn't support fragments");  
return;  
}  
writer.WriteStartElement("Root");  
fragmentWriter.StartFragment(fragmentStream, false);  
writer.WriteStartElement("Body");  
writer.WriteString("This is my body");  
writer.WriteEndElement();  
fragmentWriter.EndFragment();  
writer.WriteStartElement("CharsInTheBody");  
writer.WriteValue(fragmentStream.Length);  
writer.WriteEndElement();  
fragmentWriter.WriteFragment(fragmentStream.GetBuffer(), 0, (int)fragmentStream.Length);  
writer.WriteEndElement(); // Root  

Комментарии

Записывает фрагмент, захваченный между StartFragment и EndFragment, и выполняет обратный вызов в основной поток XmlDictionaryWriter. Записанный фрагмент содержит count байт, начиная с индекса offset, от предоставленного buffer. Поведение может быть неопределенным, если предоставленный фрагмент не был захвачен с помощью экземпляра модуля записи.

Применяется к