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 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.

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