hash

package
v1.26.2 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: May 16, 2026 License: MIT Imports: 1 Imported by: 0

Documentation

Overview

hash パッケージはハッシュ関数のためのインターフェースを提供します。

Example (BinaryMarshaler)
package main

import (
	"github.com/shogo82148/std/bytes"
	"github.com/shogo82148/std/crypto/sha256"
	"github.com/shogo82148/std/encoding"
	"github.com/shogo82148/std/fmt"
	"github.com/shogo82148/std/log"
)

func main() {
	const (
		input1 = "The tunneling gopher digs downwards, "
		input2 = "unaware of what he will find."
	)

	first := sha256.New()
	first.Write([]byte(input1))

	marshaler, ok := first.(encoding.BinaryMarshaler)
	if !ok {
		log.Fatal("first does not implement encoding.BinaryMarshaler")
	}
	state, err := marshaler.MarshalBinary()
	if err != nil {
		log.Fatal("unable to marshal hash:", err)
	}

	second := sha256.New()

	unmarshaler, ok := second.(encoding.BinaryUnmarshaler)
	if !ok {
		log.Fatal("second does not implement encoding.BinaryUnmarshaler")
	}
	if err := unmarshaler.UnmarshalBinary(state); err != nil {
		log.Fatal("unable to unmarshal hash:", err)
	}

	first.Write([]byte(input2))
	second.Write([]byte(input2))

	fmt.Printf("%x\n", first.Sum(nil))
	fmt.Println(bytes.Equal(first.Sum(nil), second.Sum(nil)))
}
Output:
57d51a066f3a39942649cd9a76c77e97ceab246756ff3888659e6aa5a07f4a52
true

Index

Examples

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type Cloner added in v1.25.0

type Cloner interface {
	Hash
	Clone() (Cloner, error)
}

Clonerは状態をクローンできるハッシュ関数で、 同等で独立した状態を持つ値を返します。

標準ライブラリのすべての Hash 実装は、GOFIPS140=v1.0.0が設定されていない限り、 このインターフェースを実装しています。

ハッシュが実行時にのみクローン可能かどうかを判断できる場合(例:別のハッシュをラップしている場合)、 CloneはErrUnsupportedをラップしたエラーを返すことがあります。 それ以外の場合、Cloneは常にnilエラーを返さなければなりません。

type Hash

type Hash interface {
	io.Writer

	Sum(b []byte) []byte

	Reset()

	Size() int

	BlockSize() int
}

Hashはすべてのハッシュ関数で実装される共通のインターフェースです。

標準ライブラリのハッシュ実装(例:hash/crc32crypto/sha256)は、encoding.BinaryMarshalerencoding.BinaryAppenderencoding.BinaryUnmarshaler、および Cloner インターフェースを実装しています。ハッシュ実装の マーシャリングにより、その内部状態を保存し、以前にハッシュに書き込まれたデータを 再書き込みすることなく、後で追加処理に使用することができます。 ハッシュ状態には、入力の一部が元の形で含まれている可能性があり、 ユーザーは可能なセキュリティ上の影響を処理することが期待されます。

互換性:ハッシュまたは暗号パッケージへの将来の変更は、 以前のバージョンでエンコードされた状態を保持することを目指します。 つまり、パッケージのリリースバージョンは、 以前のリリースバージョンで書かれたデータをデコードすることができるはずです。 ただし、セキュリティ修正などの問題により、異なる結果となる場合があります。 背景については、Goの互換性文書を参照してください:https://golang.org/doc/go1compat

type Hash32

type Hash32 interface {
	Hash
	Sum32() uint32
}

Hash32はすべての32ビットハッシュ関数によって実装される共通インターフェースです。

type Hash64

type Hash64 interface {
	Hash
	Sum64() uint64
}

Hash64は、すべての64ビットハッシュ関数によって実装される共通のインタフェースです。

type XOF added in v1.25.0

type XOF interface {
	io.Writer

	io.Reader

	Reset()

	BlockSize() int
}

XOF (extendable output function) は任意または無制限の出力長を持つハッシュ関数です。

Directories

Path Synopsis
adler32パッケージはAdler-32チェックサムを実装しています。
adler32パッケージはAdler-32チェックサムを実装しています。
crc32パッケージは32ビットの巡回冗長検査 (CRC-32) チェックサムを実装しています。
crc32パッケージは32ビットの巡回冗長検査 (CRC-32) チェックサムを実装しています。
crc64パッケージは64ビットの巡回冗長検査(CRC-64)チェックサムを実装しています。
crc64パッケージは64ビットの巡回冗長検査(CRC-64)チェックサムを実装しています。
fnvパッケージは、 Glenn Fowler、Landon Curt Noll、およびPhong Voによって作成された FNV-1およびFNV-1aという非暗号化ハッシュ関数を実装しています。
fnvパッケージは、 Glenn Fowler、Landon Curt Noll、およびPhong Voによって作成された FNV-1およびFNV-1aという非暗号化ハッシュ関数を実装しています。
Package maphashはバイトシーケンスと比較可能な値に対するハッシュ関数を提供します。
Package maphashはバイトシーケンスと比較可能な値に対するハッシュ関数を提供します。

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL