IBinarySerialize.Write(BinaryWriter) Metoda
Definice
Důležité
Některé informace platí pro předběžně vydaný produkt, který se může zásadně změnit, než ho výrobce nebo autor vydá. Microsoft neposkytuje žádné záruky, výslovné ani předpokládané, týkající se zde uváděných informací.
Převede uživatelem definovaný typ (UDT) nebo uživatelem definovanou agregaci do binárního formátu, aby mohl být trvale zachován.
public:
void Write(System::IO::BinaryWriter ^ w);
public void Write (System.IO.BinaryWriter w);
abstract member Write : System.IO.BinaryWriter -> unit
Public Sub Write (w As BinaryWriter)
Parametry
Datový BinaryWriter proud, do kterého je serializován UDT nebo uživatelem definovaná agregace.
Příklady
Následující příklad ukazuje implementaci Write metody UDT, která používá BinaryWriter k serializaci UDT v uživatelem definovaném binárním formátu. Účelem odsazení znaků null je zajistit, aby hodnota řetězce byla zcela oddělena od dvojité hodnoty, takže jeden UDT je porovnán s jinou v kódu Transact-SQL, řetězcové bajty se porovnávají s řetězcovými bajty a dvojité bajty se porovnávají s dvojitými bajty.
// The binary layout is as follows:
// Bytes 0 - 19: string text, padded to the right with null characters
// Bytes 20+: Double value
// using Microsoft.SqlServer.Server;
public void Write(System.IO.BinaryWriter w)
{
int maxStringSize = 20;
string stringValue = "The value of PI: ";
string paddedString;
double value = 3.14159;
// Pad the string from the right with null characters.
paddedString = stringValue.PadRight(maxStringSize, '\0');
// Write the string value one byte at a time.
for (int i = 0; i < paddedString.Length; i++)
{
w.Write(paddedString[i]);
}
// Write the double value.
w.Write(value);
}
Poznámky
Zapište do binárního datového proudu dostatek informací, aby metoda mohla Read rekonstituovat UDT nebo uživatelem definovanou agregaci.