Поделиться через


ResourceWriter.Generate Метод

Определение

Сохраняет все ресурсы в выходном потоке в системном формате по умолчанию.

public:
 virtual void Generate();
public:
 void Generate();
public void Generate ();
abstract member Generate : unit -> unit
override this.Generate : unit -> unit
member this.Generate : unit -> unit
Public Sub Generate ()

Реализации

Исключения

Ошибка ввода/вывода.

Произошла ошибка при сериализации объекта.

Этот объект ResourceWriter уже был закрыт и его хеш-таблица недоступна.

Примеры

В следующем примере кода метод используется Generate для записи всех объектов ресурсов в классе в ResourceWriter выходной поток.

using namespace System;
using namespace System::Resources;
using namespace System::IO;
int main()
{
   
   // Create a file stream to encapsulate items.resources.
   FileStream^ fs = gcnew FileStream( "items.resources",FileMode::OpenOrCreate,FileAccess::Write );
   
   // Open a resource writer to write from the stream.
   IResourceWriter^ writer = gcnew ResourceWriter( fs );
   
   // Add resources to the resource writer.
   writer->AddResource( "String 1", "First String" );
   writer->AddResource( "String 2", "Second String" );
   writer->AddResource( "String 3", "Third String" );
   
   // Generate the resources, and close the writer.
   writer->Generate();
   writer->Close();
}
using System;
using System.Resources;
using System.IO;
public class WriteResources 
{
   public static void Main(string[] args) 
   {  
       // Create a file stream to encapsulate items.resources.
       FileStream fs = new FileStream("items.resources", 
          FileMode.OpenOrCreate,FileAccess.Write);

       // Open a resource writer to write from the stream.
       IResourceWriter writer = new ResourceWriter(fs);
    
       // Add resources to the resource writer.
       writer.AddResource("String 1", "First String");
       writer.AddResource("String 2", "Second String");
       writer.AddResource("String 3", "Third String");

       // Generate the resources, and close the writer.
       writer.Generate();
       writer.Close();
    }
}
Imports System.Resources
Imports System.IO

Public Class WriteResources

  Public Shared Sub Main(ByVal args() As String)
      ' Create a file stream to encapsulate items.resources.
      Dim fs As New FileStream("items.resources", _
         FileMode.OpenOrCreate, FileAccess.Write)

      ' Open a resource writer to write from the stream.
      Dim writer = New ResourceWriter(fs)

      ' Add resources to the resource writer.
      writer.AddResource("String 1", "First String")
      writer.AddResource("String 2", "Second String")
      writer.AddResource("String 3", "Third String")

      ' Generate the resources, and close the writer.
      writer.Generate()
      writer.Close()
   End Sub

End Class

Комментарии

Метод Generate вызывается неявно методом , Close если он не вызывается кодом приложения.

Generate может быть вызван только один раз, после всех вызовов к AddResource и AddResourceData были сделаны. Если при записи ресурсов возникает исключение, выходной поток будет закрыт, чтобы предотвратить запись недопустимых сведений.

Generate не закрывает выходной поток в обычных случаях. Если вы не объединяете дополнительные данные с resources-файлом или вам не потребуется доступ к потоку после этого, следует вызвать Close после вызова Generateили просто вызвать Close.

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