Class Address


  • public class Address
    extends java.lang.Object
    Utilities to translate and verify the 1-Wire Network address.

    Q: What is a 1-Wire Network Address?

    A: A 1-Wire address is 64 bits consisting of an eight bit family code, forty eight bits of serialized data and an eight bit CRC8 of the first 56 bits.

    For example given the following address in hexadecimal:

    10 28 E9 14 00 00 00 F3

    The above is a family code 10 device with a serialized data of 28 E9 14 00 00 00, and a CRC8 of F3.

    The address can be stored in several ways:

    • As a little-endian byte array:

      byte[] address = { 0x10, (byte)0xE9, 0x14, 0x00, 0x00, 0x00, (byte)0xF3 };

    • As a big-endian long:

      long address = (long)0xF300000014E92810;

    • As a big-endian String:

      String address = "F300000014E92810";

    • Method Summary

      All Methods Static Methods Concrete Methods 
      Modifier and Type Method Description
      static boolean isValid​(byte[] address)
      Checks the CRC8 calculation of this 1-Wire Network address.
      static boolean isValid​(long address)
      Checks the CRC8 calculation of this 1-Wire Network address.
      static boolean isValid​(java.lang.String address)
      Checks the CRC8 calculation of this 1-Wire Network address.
      static byte[] toByteArray​(long address)
      Convert an iButton or 1-Wire device address as a long (little endian) into an array of bytes.
      static byte[] toByteArray​(java.lang.String address)
      Converts a 1-Wire Network Address string (big endian) to a byte array (little endian).
      static long toLong​(byte[] address)
      Converts a 1-Wire Network Address to a long (little endian).
      static long toLong​(java.lang.String address)
      Converts a 1-Wire Network Address to a long (little endian).
      static java.lang.String toString​(byte[] address)
      Converts a 1-Wire Network address byte array (little endian) to a hex string representation (big endian).
      static java.lang.String toString​(long address)
      Converts a 1-Wire Network address long (little endian) to a hex string representation (big endian).
      • Methods inherited from class java.lang.Object

        clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
    • Method Detail

      • isValid

        public static boolean isValid​(byte[] address)
        Checks the CRC8 calculation of this 1-Wire Network address.

        The address is valid if the CRC8 of the first seven bytes of the address gives a result equal to the eighth byte.

        Parameters:
        address - iButton or 1-Wire Network address to verify
        Returns:
        true if the family code is non-zero and the CRC8 calculation is correct.
        See Also:
        CRC8
      • isValid

        public static boolean isValid​(java.lang.String address)
        Checks the CRC8 calculation of this 1-Wire Network address.

        The address is valid if the CRC8 of the first seven bytes of the address gives a result equal to the eighth byte.

        Parameters:
        address - iButton or 1-Wire Network address to verify
        Returns:
        true if the family code is non-zero and the CRC8 calculation is correct.
        See Also:
        CRC8
      • isValid

        public static boolean isValid​(long address)
        Checks the CRC8 calculation of this 1-Wire Network address.

        The address is valid if the CRC8 of the first seven bytes of the address gives a result equal to the eighth byte.

        Parameters:
        address - iButton or 1-Wire Network address to verify
        Returns:
        true if the family code is non-zero and the CRC8 calculation is correct.
        See Also:
        CRC8
      • toString

        public static java.lang.String toString​(byte[] address)
        Converts a 1-Wire Network address byte array (little endian) to a hex string representation (big endian).
        Parameters:
        address - family code first.
        Returns:
        address represented in a String, family code last.
      • toString

        public static java.lang.String toString​(long address)
        Converts a 1-Wire Network address long (little endian) to a hex string representation (big endian).
        Parameters:
        address - family code first.
        Returns:
        address represented in a long, little endian.
      • toByteArray

        public static byte[] toByteArray​(java.lang.String address)
        Converts a 1-Wire Network Address string (big endian) to a byte array (little endian).
        Parameters:
        address - family code last.
        Returns:
        address represented in a byte array, family code (LS byte) first.
      • toByteArray

        public static byte[] toByteArray​(long address)
        Convert an iButton or 1-Wire device address as a long (little endian) into an array of bytes.
      • toLong

        public static long toLong​(byte[] address)
        Converts a 1-Wire Network Address to a long (little endian).
        Returns:
        address represented as a long.
      • toLong

        public static long toLong​(java.lang.String address)
        Converts a 1-Wire Network Address to a long (little endian).
        Returns:
        address represented as a String.