第7章 コンパイラーおよび開発ツール
以下の章では、コンパイラーおよび開発ツールに関する RHEL 8 と RHEL 9 の間の最も重要な変更点を説明します。
7.1. LLVM、Rust、および Go への注目すべき変更 リンクのコピーリンクがクリップボードにコピーされました!
LLVM Toolset が 19.1.7 に更新される
LLVM Toolset がバージョン 19.1.7 に更新されました。
LLVM コンパイラーの主な変更点:
- LLVM は、デバッグ情報をより効率的に表現する デバッグレコード を使用するようになりました。
Clang の主な更新:
- C++14 サイズの割り当て解除がデフォルトで有効になりました。
- C++17 のサポートが完了しました。
- 特にモジュール、概念、Class Template Argument Deduction (CTAD) に関する C++20 へのサポートが改善されました。
- C23、C2c、C23、C2y のサポートが改善されました。
詳細は、LLVM リリースノート および Clang リリースノート を参照してください。
LLVM Toolset は Rolling Application Stream であり、最新バージョンのみがサポートされます。詳細は、Red Hat Enterprise Linux Application Streams ライフサイクル ドキュメントを参照してください。
Rust Toolset がバージョン 1.84.0 にリベース
Rust Toolset がバージョン 1.84.0 に更新されました。以前提供されていたバージョン 1.79.0 以降の主な機能拡張は次のとおりです。
-
新しい
LazyCellおよびLazyLockタイプは、最初の使用時まで初期化を遅延します。これらは、各インスタンスに初期化関数が含まれた以前のOnceCellおよびOnceLockタイプを拡張します。 - 標準ライブラリーの新しいソート実装により、実行時のパフォーマンスとコンパイル時間が向上します。また、コンパレーターが完全な順序を生成していない場合を検出し、ソートされていないデータを返す代わりにパニックを発生させるようにしています。
-
不透明な戻り値の型の正確なキャプチャーが追加されました。新しい
use<..>構文は、impl Trait戻り値の型で使用されるジェネリックパラメーターと有効期間を指定します。 constコードに多くの新機能が追加されました。以下に例を示します。- 浮動小数点サポート
-
インラインアセンブリーの
constimmediate - 静的なものへの参照
- ミュータブルな参照とポインター
unsafeコードに対する多くの新機能が追加されました。次に例を示します。- 厳密な履歴管理 API
-
&rawポインター構文 - 静的なものを安全に処理する
-
安全でない
externブロック内で安全な項目を宣言する
-
Cargo 依存関係リゾルバーはバージョンを認識するようになりました。依存関係クレートがサポートされる最小 Rust バージョンを指定している場合、Cargo は依存関係グラフを解決するときに、最新の
semver互換のクレートバージョンを使用する代わりに、この情報を使用します。
互換性に関する注意事項:
-
WebAssembly System Interface (WASI) ターゲットが
rust-std-static-wasm32-wasiからrust-std-static-wasm32-wasip1に変更されました。コマンドラインで--target wasm32-wasip1パラメーターを使用して WASI ターゲットを選択することもできます。詳細は、アップストリームブログ投稿 Changes to Rust’s WASI targets を参照してください。 -
分割されたパニックフックとパニックハンドラー引数
core::panic::PanicInfoとstd::panic::PanicInfoは異なる型になりました。 -
extern "C"関数は、キャッチされないパニックが発生すると中止するようになりました。ABI 境界を越えてアンワインドできるようにするには、代わりにextern "C-unwind"を使用します。
Rust Toolset は Rolling Application Stream であり、Red Hat は最新バージョンのみをサポートします。詳細は、Red Hat Enterprise Linux Application Streams ライフサイクル ドキュメントを参照してください。
Go Toolset がバージョン 1.23 にリベース
Go Toolset がバージョン 1.23 に更新されました。主な機能拡張は、次のとおりです。
for-rangeループは、次のタイプのイテレーター関数を受け入れます。-
func(func() bool) -
func(func(K) bool) func(func(K, V) bool)for-rangeループの反復値は、イテレーター引数関数の呼び出しによって作成されます。参照リンクは、アップストリームのリリースノート を参照してください。
-
- Go Toolchain により、使用状況や破損統計情報を収集できます。これは、Go チームが Go Toolchain がどのように使用され、どのように機能するかを理解するのに役立ちます。デフォルトでは、Go Telemetry はテレメトリーデータをアップロードせず、ローカルにのみ保存します。詳細は、アップストリームの Go Telemetry ドキュメント を参照してください。
-
go vetサブコマンドには、参照ファイルで使用する Go のバージョンに対して新しすぎるシンボルへの参照にフラグを立てるstdversionアナライザーが含まれています。 -
cmdおよびcgo機能は、C リンカーにフラグを渡すための-ldflagsオプションをサポートしています。goコマンドは、非常に大きなCGO_LDFLAGS環境変数を使用する場合に、argument list too longエラーを回避するために、このフラグを自動的に使用します。 -
traceユーティリティーは、部分的に壊れたトレースを許容し、トレースデータを回復しようとします。これはクラッシュが発生した場合にクラッシュに至るまでのトレースを取得できるため、特に便利です。 -
未処理のパニックまたはその他の致命的なエラーの後にランタイムによって出力されるトレースバックには、
goroutineのスタックトレースを最初のgoroutineと区別するためのインデントが含まれます。 - プロファイルガイドによる最適化を使用したコンパイラービルド時間のオーバーヘッドが 1 桁のパーセンテージに削減されました。
-
新しい
-bindnowリンカーフラグにより、動的にリンクされた ELF バイナリーをビルドするときに即時の関数バインディングが有効になります。 -
//go:linknameリンカーディレクティブは、標準ライブラリー内の内部シンボルと、定義に//go:linknameのマークが付けられていないランタイムを参照しなくなりました。 -
プログラムが
TimerまたはTickerを参照しなくなった場合、Stopメソッドが呼び出されていなくても、これらはガベージコレクションによってすぐにクリーンアップされます。TimerまたはTickerに関連付けられたタイマーチャネルは、現在バッファーなし (容量 0) になっています。これにより、ResetメソッドまたはStopメソッドが呼び出されるたびに、呼び出し後に古い値が送受信されなくなります。 -
新しい
uniqueパッケージは、interningまたはhash-consingなどの値を正規化する機能を提供します。 -
新しい
iterパッケージは、ユーザー定義のイテレーターを使用するための基本的な定義を提供します。 -
slicesおよびmapsパッケージには、イテレーターで使用するいくつかの新しい関数が導入されています。 -
新しい
structsパッケージは、メモリーレイアウトなど、含まれる struct 型のプロパティーを変更する struct フィールドの型を提供します。 次のパッケージにマイナーな変更が加えられました。
-
archive/tar -
crypto/tls -
crypto/x509 -
database/sql -
debug/elf -
encoding/binary -
go/ast -
go/types -
math/rand/v2 -
net -
net/http -
net/http/httptest -
net/netips -
path/filepath -
reflect -
runtime/debug -
runtime/pprof -
runtime/trace -
slices -
sync -
sync/atomic -
syscall -
testing/fstest -
text/template -
time -
unicode/utf16
-
詳細は、アップストリームのリリースノート を参照してください。
Go Toolset は Rolling Application Stream であり、Red Hat は最新バージョンのみをサポートします。詳細は、Red Hat Enterprise Linux Application Streams ライフサイクル ドキュメントを参照してください。