泛型數學
針對 ISO C Standard 11 (C11) 和更新版本,標頭 <tgmath.h>
除了包含 <math.h>
和 <complex.h>
之外,還提供根據參數類型叫用對應數學函式的巨集。
C 執行時間連結庫數學函式會以真實且複雜的變體提供。 每個變數都有三種變體,視自變數的類型而定: float
、 double
和 long double
。 因為 C 不支援像C++一樣多載,因此每個變體都有不同的名稱。 例如,若要取得實際浮點值的絕對值,您可以分別呼叫 fabsf
、 fabs
或 ,或 fabsl
取決於您要分別傳遞 float
、 double
或 long double
值。 若要取得複雜絕對值,您可以分別呼叫、 cabsf
cabs
或 的其中一個float
, 或 cabsl
,視您是否分別傳遞、 double
和 long double
複雜值而定。 如果自變數不符合上述任何類型,則會選擇函式,就像自變數是雙精度浮點數一樣。
<tgmath.h>
包含巨集,可簡化要呼叫的正確數學函式選取範圍。 巨集會檢查其傳遞的類型,然後呼叫正確的函式。 例如, sqrt
巨集會 sqrt(9.9f)
系結至 sqrtf()
,但它會 sqrt(9.9)
系結至 sqrt()
。 如果泛型參數至少有一個巨集自變數很複雜,則巨集會系結至複雜函式;否則,它會叫用實際函式。
中的 <tgmath.h>
類型泛型巨集可讓您撰寫更多可攜式程式代碼,因為您不需要根據自變數類型來管理轉換或選取不同的函式名稱。
這些巨集位於自己的標頭中,因此使用 <math.h>
標頭撰寫的程式不會中斷。 因此 double x = sin(42);
,當您包含 <math.h> 時,其行為一如既往。 即便如此,當標頭包含 而不是 <math.h>
或 <complex.h>
時<tgmath.h>
,大部分現有的 C 程式應該不會受到影響。
下表列出 中 <tgmath.h>
可用的巨集,以及其展開範圍。 modf
未包含在此數據表中,因為它沒有對應的類型泛型巨集,因為它不清楚如何使其安全,而不會使類型解析複雜化。
需求
使用 /std:c11
編譯。
Windows SDK 10.0.20348.0 (版本 2104) 或更新版本。 請參閱 Windows SDK 以下載最新的 SDK。 如需安裝和使用適用於 C11 和 C17 開發的 SDK 的指示,請參閱在 Visual Studio 中安裝 C11 和 C17 支援。