首頁 >後端開發 >C++ >C 和 C 中的陷阱表示形式是什麼,相同大小的浮點數及其指標是否共享相同的二進位表示形式?

C 和 C 中的陷阱表示形式是什麼,相同大小的浮點數及其指標是否共享相同的二進位表示形式?

DDD
DDD原創
2024-12-18 22:45:20714瀏覽

What are Trap Representations in C and C  , and Do Identical-Sized Floats and Their Pointers Share the Same Binary Representation?

陷阱表示

問題:

  1. 問題:
  2. 在什麼是「陷阱表示」 C 中?
這適用於 C ?

兩個變數(一個浮點型和一個指向浮點型的指標)如果大小相同,是否具有相同的二進位表示?

答案:

1。陷阱表示:

在 C 中,陷阱表示是一種位元模式,適合類型的大小,但如果用作該類型的值,則會導致未定義的行為。任何類型都不需要具有陷阱表示,但唯一保證不具有陷阱表示的類型是 unsigned char。 陷阱表示的一個範例是浮點類型中的訊號 NaN。這些模式在 C99 中未定義。

2。對 C 的適用性:

雖然問題沒有提到 C ,但值得注意的是陷阱表示的概念也適用於 C。

3.浮點和指標的二進位表示:
float f = 3.5;
int *pi = (int*)&f;

下面提供的程式碼表現出未定義的行為:
int extract_int(float f)
{
    union { int i; float f; } u;
    u.f = f;
    return u.i;
}

但是,此行為與陷阱表示無關。若要取得與浮點數具有相同位元模式的整數值,請使用下列程式碼:此程式碼在C99 中表現出未指定的行為,這表示標準沒有定義產生的確切整數值,但它保證獲得有效的整數值。因此,浮點數的二進位表示形式和使用聯合獲得的整數不能保證相同。

以上是C 和 C 中的陷阱表示形式是什麼,相同大小的浮點數及其指標是否共享相同的二進位表示形式?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn