PingOptions Classe

Definição

Usado para controlar como pacotes de dados Ping são transmitidos.

public ref class PingOptions
public class PingOptions
type PingOptions = class
Public Class PingOptions
Herança
PingOptions

Exemplos

O exemplo de código a seguir usa as Pingclasses e PingOptionsPingReply para enviar uma solicitação de eco ICMP para o host especificado na linha de comando.

#using <System.dll>

using namespace System;
using namespace System::Net;
using namespace System::Net::NetworkInformation;
using namespace System::Text;

// args[1] can be an IPaddress or host name.
int main()
{
   array<String^>^args = Environment::GetCommandLineArgs();
   
   Ping ^ pingSender = gcnew Ping;
   PingOptions ^ options = gcnew PingOptions;
   
   // Use the default Ttl value which is 128,
   // but change the fragmentation behavior.
   options->DontFragment = true;
   
   // Create a buffer of 32 bytes of data to be transmitted.
   String^ data = "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa";
   array<Byte>^buffer = Encoding::ASCII->GetBytes( data );
   int timeout = 120;
   PingReply ^ reply = pingSender->Send( args[ 1 ], timeout, buffer, options );
   
   if ( reply->Status == IPStatus::Success )
   {
      Console::WriteLine( "Address: {0}", reply->Address->ToString() );
      Console::WriteLine( "RoundTrip time: {0}", reply->RoundtripTime );
      Console::WriteLine( "Time to live: {0}", reply->Options->Ttl );
      Console::WriteLine( "Don't fragment: {0}", reply->Options->DontFragment );
      Console::WriteLine( "Buffer size: {0}", reply->Buffer->Length );
   }

   
}
using System;
using System.Net;
using System.Net.NetworkInformation;
using System.Text;

namespace Examples.System.Net.NetworkInformation.PingTest
{
    public class PingExample
    {
        // args[0] can be an IPaddress or host name.
        public static void Main (string[] args)
        {
            Ping pingSender = new Ping ();
            PingOptions options = new PingOptions ();

            // Use the default Ttl value which is 128,
            // but change the fragmentation behavior.
            options.DontFragment = true;

            // Create a buffer of 32 bytes of data to be transmitted.
            string data = "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa";
            byte[] buffer = Encoding.ASCII.GetBytes (data);
            int timeout = 120;
            PingReply reply = pingSender.Send (args[0], timeout, buffer, options);
            if (reply.Status == IPStatus.Success)
            {
                Console.WriteLine ("Address: {0}", reply.Address.ToString ());
                Console.WriteLine ("RoundTrip time: {0}", reply.RoundtripTime);
                Console.WriteLine ("Time to live: {0}", reply.Options.Ttl);
                Console.WriteLine ("Don't fragment: {0}", reply.Options.DontFragment);
                Console.WriteLine ("Buffer size: {0}", reply.Buffer.Length);
            }
        }
    }
}
open System.Net.NetworkInformation
open System.Text

// args[0] can be an IPaddress or host name.
[<EntryPoint>]
let main args =
    let pingSender = new Ping()

    // Use the default Ttl value which is 128,
    // but change the fragmentation behavior.
    let options = PingOptions()
    options.DontFragment <- true

    // Create a buffer of 32 bytes of data to be transmitted.
    let data = "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
    let buffer = Encoding.ASCII.GetBytes data
    let timeout = 120
    let reply: PingReply = pingSender.Send(args.[0], timeout, buffer, options)

    match reply.Status with
    | IPStatus.Success ->
        printfn "Address: %O" reply.Address
        printfn "RoundTrip time: %d" reply.RoundtripTime
        printfn "Time to live: %d" reply.Options.Ttl
        printfn "Don't fragment: %b" reply.Options.DontFragment
        printfn "Buffer size: %d" reply.Buffer.Length
        0
    | _ ->
        eprintfn "Error sending ping: %O" reply
        eprintfn "Error was: %O" reply.Status
        1

Comentários

A PingOptions classe fornece as Ttl propriedades e DontFragment para controlar como os pacotes de solicitação de eco do protocolo ICMP são transmitidos.

A Ttl propriedade especifica a Vida Útil para pacotes enviados pela Ping classe . Esse valor indica o número de nós de roteamento que podem encaminhar um Ping pacote antes que ele seja descartado. Definir essa opção é útil se você quiser testar o número de encaminhamentos, também conhecidos como saltos, são necessários para enviar um pacote de um computador de origem para um computador de destino.

A DontFragment propriedade controla se os dados enviados para um host remoto podem ser divididos em vários pacotes. Essa opção será útil se você quiser testar a MTU (unidade de transmissão máxima) dos roteadores e gateways usados para transmitir o pacote.

As instâncias da PingOptions classe são passadas para os Send métodos e SendAsync e a PingReply classe retorna instâncias de PingOptions por meio da Options propriedade .

Para obter uma lista de valores de propriedade iniciais para uma instância do PingOptions, consulte o PingOptions construtor .

Construtores

PingOptions()

Inicializa uma nova instância da classe PingOptions.

PingOptions(Int32, Boolean)

Inicializa uma nova instância da classe PingOptions e define os valores de fragmentação e vida útil.

Propriedades

DontFragment

Obtém ou define um valor Boolean que controla a fragmentação dos dados enviados para o host remoto.

Ttl

Obtém ou define o número de nós de roteamento podem encaminhar os dados de Ping antes de serem descartados.

Métodos

Equals(Object)

Determina se o objeto especificado é igual ao objeto atual.

(Herdado de Object)
GetHashCode()

Serve como a função de hash padrão.

(Herdado de Object)
GetType()

Obtém o Type da instância atual.

(Herdado de Object)
MemberwiseClone()

Cria uma cópia superficial do Object atual.

(Herdado de Object)
ToString()

Retorna uma cadeia de caracteres que representa o objeto atual.

(Herdado de Object)

Aplica-se a