Прочитать на английском

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


DuplicateAddressDetectionState Перечисление

Определение

Указывает текущее состояние IP-адреса.

C#
public enum DuplicateAddressDetectionState
Наследование
DuplicateAddressDetectionState

Поля

Имя Значение Описание
Deprecated 3

Адрес действителен, но его срок аренды истекает и он не должен использоваться приложениями.

Duplicate 2

Адрес не является уникальным. Этот адрес не должен назначаться сетевому интерфейсу.

Invalid 0

Недопустимый адрес. У недопустимого адреса истек срок действия и он больше не назначен интерфейсу. Приложения не должны отправлять данные на этот адрес.

Preferred 4

Адрес действителен и может использоваться без ограничений.

Tentative 1

Оценка процедуры обнаружения повторяющихся адресов не была успешно завершена. Этот адрес не должен использоваться приложениями, потому что он еще недопустим и отправляемые на него пакеты удаляются.

Примеры

В следующем примере кода определяются сведения об адресе одноадресной рассылки.

C#
public static void DisplayUnicastAddresses()
{
    Console.WriteLine("Unicast Addresses");
    NetworkInterface[] adapters  = NetworkInterface.GetAllNetworkInterfaces();
    foreach (NetworkInterface adapter in adapters)
    {
        IPInterfaceProperties adapterProperties = adapter.GetIPProperties();
        UnicastIPAddressInformationCollection uniCast = adapterProperties.UnicastAddresses;
        if (uniCast.Count >0)
        {
            Console.WriteLine(adapter.Description);
            string lifeTimeFormat = "dddd, MMMM dd, yyyy  hh:mm:ss tt";
            foreach (UnicastIPAddressInformation uni in uniCast)
            {
                DateTime when;

                Console.WriteLine("  Unicast Address ......................... : {0}", uni.Address);
                Console.WriteLine("     Prefix Origin ........................ : {0}", uni.PrefixOrigin);
                Console.WriteLine("     Suffix Origin ........................ : {0}", uni.SuffixOrigin);
                Console.WriteLine("     Duplicate Address Detection .......... : {0}",
                    uni.DuplicateAddressDetectionState);

                // Format the lifetimes as Sunday, February 16, 2003 11:33:44 PM
                // if en-us is the current culture.

                // Calculate the date and time at the end of the lifetimes.
                when = DateTime.UtcNow + TimeSpan.FromSeconds(uni.AddressValidLifetime);
                when = when.ToLocalTime();
                Console.WriteLine("     Valid Life Time ...................... : {0}",
                    when.ToString(lifeTimeFormat,System.Globalization.CultureInfo.CurrentCulture)
                );
                when = DateTime.UtcNow + TimeSpan.FromSeconds(uni.AddressPreferredLifetime);
                when = when.ToLocalTime();
                Console.WriteLine("     Preferred life time .................. : {0}",
                    when.ToString(lifeTimeFormat,System.Globalization.CultureInfo.CurrentCulture)
                );

                when = DateTime.UtcNow + TimeSpan.FromSeconds(uni.DhcpLeaseLifetime);
                when = when.ToLocalTime();
                Console.WriteLine("     DHCP Leased Life Time ................ : {0}",
                    when.ToString(lifeTimeFormat,System.Globalization.CultureInfo.CurrentCulture)
                );
            }
            Console.WriteLine();
        }
    }
}

Комментарии

Чтобы убедиться, что все интерфейсы в сети имеют уникальный адрес, узел интерфейса отвечает за выполнение алгоритма обнаружения повторяющихся адресов на одноадресных адресах. Цель этого алгоритма — попытаться предотвратить неуникальный адрес в сети. Этот процесс определен в IETF RFC 1971.

Это перечисление используется классами UnicastIPAddressInformation и MulticastIPAddressInformation . Экземпляры этого класса возвращаются при получении сведений об адресе одноадресной рассылки NetworkInterface для объекта .

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

Продукт Версии
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 2.0, 2.1