亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

目錄 搜尋
Algorithms Algorithms(算法) bsearch bsearch_s qsort qsort_s Atomic operations Atomic operations library(原子操作庫(kù)) ATOMIC_*_LOCK_FREE atomic_compare_exchange_strong atomic_compare_exchange_strong_explicit atomic_compare_exchange_weak atomic_compare_exchange_weak_explicit atomic_exchange atomic_exchange_explicit atomic_fetch_add atomic_fetch_add_explicit atomic_fetch_and atomic_fetch_and_explicit atomic_fetch_or atomic_fetch_or_explicit atomic_fetch_sub atomic_fetch_sub_explicit atomic_fetch_xor atomic_fetch_xor_explicit atomic_flag atomic_flag_clear atomic_flag_clear_explicit ATOMIC_FLAG_INIT atomic_flag_test_and_set atomic_flag_test_and_set_explicit atomic_init atomic_is_lock_free atomic_load atomic_load_explicit atomic_signal_fence atomic_store atomic_store_explicit atomic_thread_fence(線程圍欄) ATOMIC_VAR_INIT kill_dependency memory_order(內(nèi)存排序) C keywords auto(自動(dòng)存儲(chǔ)) break(跳出循環(huán)) C keywords(關(guān)鍵詞) case char const(常量修飾符) continue default(預(yù)設(shè)運(yùn)算式) do double(雙精度浮點(diǎn)型) else enum(枚舉類型) extern(全局變量) float(浮點(diǎn)數(shù)) for fortran goto(goto語(yǔ)句) if(if語(yǔ)句) inline(行內(nèi)函式) int long(長(zhǎng)整型) register(寄存器變量) restrict( restrict類型限定符) return short signed sizeof(sizeof運(yùn)算符) static(靜態(tài)變量) struct(結(jié)構(gòu)體) switch(switch語(yǔ)句) typedef(typedef關(guān)鍵字) union(聯(lián)合體) unsigned(無(wú)符號(hào)) void(空類型) volatile(volatile變量) while(while語(yǔ)句) _Alignas _Alignof _Atomic _Bool _Complex _Generic _Imaginary _Noreturn _Static_assert _Thread_local C language #define directive #elif directive #else directive #endif directive #error directive #if directive #ifdef directive #ifndef directive #include directive #line directive #pragma directive alignas(對(duì)齊指定符) Alternative operators and tokens(替代運(yùn)算符和令牌) Analyzability Arithmetic operators Arithmetic types Array declaration(數(shù)組聲明) Array initialization(陣列初始化) ASCII Chart Assignment operators(賦值運(yùn)算符) types(atomic類型限定符) Basic concepts Bit fields(位域) break statement C language C Operator Precedence cast operator character constant(字符字面量) Comments(注釋符) Comparison operators(比較運(yùn)算符) compound literals(符合字面量) Conditional inclusion(條件包含) Conformance(一致性) const type qualifier(const 限定符) Constant expressions(常量表達(dá)) continue statement Declarations(聲明) do-while loop Enumerations(枚舉類型) Escape sequences(轉(zhuǎn)義字符) Expressions(表達(dá)式) External and tentative definitions(外部和暫定的定義) File scope(文件范圍) floating constant(浮點(diǎn)常量) for loop Function declarations(函數(shù)聲明) Function definitions(函數(shù)聲明) Functions Generic selection泛型選擇 goto statement Identifier(標(biāo)示符) if statement Implicit conversions(隱式轉(zhuǎn)換) Increment/decrement operators(前置/后置操作符) Initialization(初始化) inline function specifier(內(nèi)聯(lián)函式) integer constant Lifetime(生命期) Logical operators(邏輯運(yùn)算符) Lookup and name spaces Main function(主函式) Member access operators(會(huì)員接入運(yùn)營(yíng)商) Memory model Objects and alignment(字節(jié)對(duì)齊) Order of evaluation(評(píng)估順序) Other operators Phases of translation(翻譯階段) Pointer declaration Preprocessor(預(yù)處理) restrict type qualifier(restrict類型限定符) return statement Scalar initialization(標(biāo)量類型初始化) Scope(范圍) sizeof operator(sizeof運(yùn)算符) Statements(陳述) static assert declaration(靜態(tài)斷言聲明) Static storage duration(靜態(tài)存儲(chǔ)周期) Storage-class specifiers(存儲(chǔ)類說明符) string literals(字符串字面量) Struct and union initialization(結(jié)構(gòu)體與聯(lián)合體初始化) Struct declaration(結(jié)構(gòu)體聲明) switch statement Thread storage duration(線程存儲(chǔ)時(shí)間) Type Type(類型) Typedef declaration(Typedef聲明) Undefined behavior(未定義行為) Union declaration(聯(lián)合體聲明) Value categories(值類別) Variadic arguments(變長(zhǎng)參數(shù)宏) volatile type qualifier(volatile 類型限定符) while loop _Alignof operator _Noreturn function specifier Date and time asctime(asctime函數(shù)) asctime_s clock CLOCKS_PER_SEC clock_t ctime(ctime函數(shù)) ctime_s Date and time utilities(日期和時(shí)間庫(kù)) difftime(計(jì)算兩個(gè)時(shí)間的間隔) gmtime gmtime_s localtime localtime_s mktime(將時(shí)間結(jié)構(gòu)數(shù)據(jù)轉(zhuǎn)換成經(jīng)過的秒數(shù)的函數(shù)) strftime(格式化輸出時(shí)間函數(shù)) time timespec timespec_get time_t tm wcsftime(格式化時(shí)間寬字符) Dynamic memory management aligned_alloc C memory management library(內(nèi)存管理庫(kù)) calloc free(釋放動(dòng)態(tài)分配空間的函數(shù)) malloc(動(dòng)態(tài)分配內(nèi)存空間的函數(shù)) realloc(重新分配內(nèi)存空間的函數(shù)) Error handling abort_handler_s assert(斷言) constraint_handler_t errno(錯(cuò)誤報(bào)告) Error handling(錯(cuò)誤處理) Error numbers(錯(cuò)誤個(gè)數(shù)) ignore_handler_s set_constraint_handler_s static_assert File input/output clearerr(清除/復(fù)位) fclose feof ferror fflush(清空文件緩沖區(qū)) fgetc fgetpos fgets fgetwc fgetws File input/output fopen fopen_s fprintf fprintf_s fputc fputs fputwc fputws fread freopen freopen_s fscanf fscanf_s fseek fsetpos ftell fwide fwprintf fwprintf_s fwrite fwscanf fwscanf_s getc getchar gets gets_s getwchar perror printf printf_s putc putchar puts putwc putwchar remove rename rewind scanf scanf_s setbuf setvbuf snprintf sprintf sscanf sscanf_s swprintf swprintf_s swscanf swscanf_s tmpfile tmpfile_s tmpnam tmpnam_s ungetc ungetwc vfprintf vfprintf_s vfscanf vfscanf_s vfwprintf vfwprintf_s vfwscanf vfwscanf_s vprintf vprintf_s vscanf vscanf_s vsnprintf vsprintf vsscanf vsscanf_s vswprintf vswprintf_s vswscanf vswscanf_s vwprintf vwprintf_s vwscanf vwscanf_s wprintf wprintf_s wscanf wscanf_s Localization support lconv LC_ALL LC_COLLATE LC_CTYPE LC_MONETARY LC_NUMERIC LC_TIME localeconv Localization support setlocale Numerics abs acos acosf acosh acoshf acoshl acosl asin asinf asinh asinhf asinhl asinl atan atan2 atan2f atan2l atanf atanh atanhf atanhl atanl cabs cabsf cabsl cacos cacosf cacosh cacoshf cacoshl cacosl carg cargf cargl casin casinf casinh casinhf casinhl casinl catan catanf catanh catanhf catanhl catanl cbrt cbrtf cbrtl ccos ccosf ccosh ccoshf ccoshl ccosl ceil ceilf ceill cexp cexpf cexpl cimag cimagf cimagl clog clogf clogl CMPLX CMPLXF CMPLXL Common mathematical functions complex Complex number arithmetic conj conjf conjl copysign copysignf copysignl cos cosf cosh coshf coshl cosl cpow cpowf cpowl cproj cprojf cprojl creal crealf creall csin csinf csinh csinhf csinhl csinl csqrt csqrtf csqrtl ctan ctanf ctanh ctanhf ctanhl ctanl div double_t erf erfc erfcf erfcl erff erfl exp exp2 exp2f exp2l expf expl expm1 expm1f expm1l fabs fabsf fabsl fdim feclearexcept fegetenv fegetexceptflag fegetround feholdexcept feraiseexcept fesetenv fesetexceptflag fesetround fetestexcept feupdateenv FE_ALL_EXCEPT FE_DFL_ENV FE_DIVBYZERO FE_DOWNWARD FE_INEXACT FE_INVALID FE_OVERFLOW FE_TONEAREST FE_TOWARDZERO FE_UNDERFLOW FE_UPWARD Floating-point environment float_t floor floorf floorl fma fmaf fmal fmax fmaxf fmaxl fmin fminf fminl fmod fmodf fmodl fpclassify FP_INFINITE FP_NAN FP_NORMAL FP_SUBNORMAL FP_ZERO frexp frexpf frexpl HUGE_VAL HUGE_VALF HUGE_VALL hypot hypotf hypotl I ilogb ilogbf ilogbl imaginary imaxabs imaxdiv INFINITY isfinite isgreater isgreaterequal isinf isless islessequal islessgreater isnan isnormal isunordered labs ldexp ldexpf ldexpl ldiv lgamma lgammaf lgammal llabs lldiv llrint llrintf llrintl llround llroundf llroundl log log10 log10f log10l log1p log1pf log1pl log2 log2f log2l logb logbf logbl logf logl lrint lrintf lrintl lround lroundf lroundl MATH_ERREXCEPT math_errhandling MATH_ERRNO modf modff modfl nan NAN nanf nanl nearbyint nearbyintf nearbyintl nextafter nextafterf nextafterl nexttoward nexttowardf nexttowardl Numerics pow powf powl Pseudo-random number generation rand RAND_MAX remainder remainderf remainderl remquo remquof remquol rint rintf rintl round roundf roundl scalbln scalblnf scalblnl scalbn scalbnf scalbnl signbit sin sinf sinh sinhf sinhl sinl sqrt sqrtf sqrtl srand tan tanf tanh tanhf tanhl tanl tgamma tgammaf tgammal trunc truncf truncl Type-generic math _Complex_I _Imaginary_I Program support abort atexit at_quick_exit exit EXIT_FAILURE EXIT_SUCCESS getenv getenv_s jmp_buf longjmp Program support utilities quick_exit raise setjmp SIGABRT SIGFPE SIGILL SIGINT signal SIGSEGV SIGTERM sig_atomic_t SIG_DFL SIG_ERR SIG_IGN system _Exit Strings atof atoi atol atoll btowc c16rtomb c32rtomb char16_t char32_t isalnum isalpha isblank iscntrl isdigit isgraph islower isprint ispunct isspace isupper iswalnum iswalpha iswblank iswcntrl iswctype iswdigit iswgraph iswlower iswprint iswpunct iswspace iswupper iswxdigit isxdigit mblen mbrlen mbrtoc16 mbrtoc32 mbrtowc mbsinit mbsrtowcs mbsrtowcs_s mbstate_t mbstowcs mbstowcs_s mbtowc memchr memcmp memcpy memcpy_s memmove memmove_s memset memset_s Null-terminated byte strings Null-terminated multibyte strings Null-terminated wide strings strcat strcat_s strchr strcmp strcoll strcpy strcpy_s strcspn strerror strerrorlen_s strerror_s Strings library strlen strncat Thread support call_once cnd_broadcast cnd_destroy cnd_init cnd_signal cnd_timedwait cnd_wait mtx_destroy mtx_init mtx_lock mtx_plain mtx_recursive mtx_timed mtx_timedlock mtx_trylock mtx_unlock once_flag ONCE_FLAG_INIT thrd_busy thrd_create thrd_current thrd_detach thrd_equal thrd_error thrd_exit thrd_join thrd_nomem thrd_sleep thrd_success thrd_timedout thrd_yield Thread support library thread_local tss_create tss_delete TSS_DTOR_ITERATIONS tss_get tss_set Type support Boolean type support library Fixed width integer types FLT_EVAL_METHOD FLT_ROUNDS max_align_t NULL Numeric limits offsetof ptrdiff_t size_t Type support Variadic functions Variadic functions va_arg va_copy va_end va_list va_start
文字

(另請(qǐng)參閱類型系統(tǒng)概述的類型以及由C庫(kù)提供的與類型相關(guān)的實(shí)用程序的列表)。

  • _Bool (也可以作為宏布爾) - 類型,能夠保存兩個(gè)值之一:1和0(也可以通過宏來訪問true和false)。

請(qǐng)注意,conversion to _Bool與轉(zhuǎn)換為其他整數(shù)類型的轉(zhuǎn)換不同:(bool)0.5評(píng)估為1,而(int)0.5評(píng)估為0。

(since C99)

字符類型

  • signed char  - 輸入有符號(hào)字符表示。

  • unsigned char - 輸入無(wú)符號(hào)字符表示。還用于檢查對(duì)象表示(原始內(nèi)存)。

  • char - 字符表示的類型。等同于signed char或者unsigned char(哪一個(gè)是實(shí)現(xiàn)定義的,并且可以由編譯器命令行開關(guān)控制),但是char是不同的類型,不同于signed char兩者unsigned char

請(qǐng)注意,標(biāo)準(zhǔn)庫(kù)還定義了用于表示寬字符的typedef名稱wchar_t,char16_t和char32_t(自C11起)。

整數(shù)類型

  • short int(也可以訪問short,可以使用關(guān)鍵字signed

  • unsigned short int(也可以訪問unsigned short

  • int(也可以訪問signed int

  • unsigned int(也可以訪問unsignedint,實(shí)現(xiàn)模運(yùn)算的未簽名對(duì)應(yīng)方。適用于位操作。

  • long int(也可以訪問long

  • unsigned long int(也可以訪問unsigned long

這是該平臺(tái)的最佳整數(shù)類型,并且保證至少為16位。大多數(shù)當(dāng)前系統(tǒng)使用32位(請(qǐng)參見下面的數(shù)據(jù)模型)。

  • long long int(也可以訪問long long

  • unsigned long long int(也可以訪問unsigned long long

(since C99)

注意:與所有類型說明符一樣,任何次序都是允許的:unsigned long long intlong int unsigned long命名相同的類型。

下表總結(jié)了所有可用的整數(shù)類型及其屬性:

類型說明符

等效類型

數(shù)據(jù)模型的位寬





C標(biāo)準(zhǔn)

LP32

ILP32

LLP64

LP64



短整型

至少為16

16

16

16

16

除了最小的位數(shù)外,C標(biāo)準(zhǔn)保證了:   1 == sizeof(char) <= sizeof(short) <= sizeof(int) <= sizeof(long) <= sizeof(long long)。

注意:這允許在極端情況下字節(jié)大小為64位,所有類型(包括char)都是64位寬,并且sizeof對(duì)于每種類型返回1。

注意:對(duì)于有符號(hào)和無(wú)符號(hào)整數(shù)類型,整數(shù)算術(shù)的定義是不同的。請(qǐng)參閱算術(shù)運(yùn)算符,特別是整數(shù)溢出。

數(shù)據(jù)模型

每種實(shí)現(xiàn)對(duì)基本類型大小的選擇統(tǒng)稱為數(shù)據(jù)模型。四個(gè)數(shù)據(jù)模型被廣泛接受:

32位系統(tǒng):

  • LP322/4/4(int是16位長(zhǎng),指針是32位)

    • Win16 API

  • ILP324/4/4(int,long和指針是32位);

    • Win32 API

    • Unix和類Unix系統(tǒng)(Linux,Mac OS X)

64位系統(tǒng):

  • LLP644/4/8(int和long是32位,指針是64位)

    • Win64 API

  • LP644/8/8(int是32位長(zhǎng),指針是64位)

    • Unix和類Unix系統(tǒng)(Linux,Mac OS X)

其他型號(hào)非常少見。例如,ILP648/8/8:int,long和指針是64位)僅出現(xiàn)在一些早期的64位Unix系統(tǒng)中(例如Cray上的Unicos)。

請(qǐng)注意,自C99開始,精確寬度的整數(shù)類型在<stdint.h>中可用。

真正的浮動(dòng)類型

C有三種類型來表示實(shí)際的浮點(diǎn)值:

  • float - 單精度浮點(diǎn)型。如果支持,匹配IEEE-754 32位浮點(diǎn)類型。

  • double - 雙精度浮點(diǎn)型。如果支持,匹配IEEE-754 64位浮點(diǎn)類型

  • long double - 擴(kuò)展精度浮點(diǎn)類型。如果支持,則匹配IEEE-754擴(kuò)展浮點(diǎn)類型,否則匹配某些非標(biāo)準(zhǔn)擴(kuò)展浮點(diǎn)類型,只要其精度優(yōu)于double且范圍至少與double一致,否則匹配類型double。一些x86和x86_64實(shí)現(xiàn)使用80位x87浮點(diǎn)類型。

浮點(diǎn)類型可能支持特殊值:

  • 無(wú)限(正面和負(fù)面),見INFINITY

  • 負(fù)零,-0.0。它類似于正零,但在一些算術(shù)運(yùn)算中有意義,例如1.0/0.0 == INFINITY而非1.0/-0.0 == -INFINITY

  • 非數(shù)字(NaN),它與任何其他內(nèi)容(包括它本身)都不相等。多位模式表示NaN的,參閱nan,NAN。請(qǐng)注意,C沒有特別注意發(fā)送NaN(由IEEE-754指定),并將所有NaN視為靜態(tài)。

實(shí)數(shù)浮點(diǎn)數(shù)可能與算術(shù)運(yùn)算符+  -  / *和math.h中的各種數(shù)學(xué)函數(shù)一起使用。內(nèi)置運(yùn)算符和庫(kù)函數(shù)都可能會(huì)引發(fā)浮點(diǎn)異常且errno按照math_errhandling中所述進(jìn)行設(shè)置。

請(qǐng)參閱,浮點(diǎn)表達(dá)式的范圍和精度可能比其類型所指示的范圍和精度要高于FLT_EVAL_METHOD。賦值,返回和強(qiáng)制將范圍和精度強(qiáng)制為與聲明類型關(guān)聯(lián)的范圍和精度。

浮點(diǎn)表達(dá)式也可能會(huì)收縮,就像所有中間值具有無(wú)限范圍和精度一樣計(jì)算,請(qǐng)參閱#pragma STDC FP_CONTRACT。

浮點(diǎn)數(shù)的一些操作受浮點(diǎn)環(huán)境的狀態(tài)(最顯著的是舍入方向)的影響和修改。

隱式轉(zhuǎn)換定義在實(shí)際浮點(diǎn)類型與整數(shù),復(fù)數(shù)和虛數(shù)類型之間。

有關(guān)浮點(diǎn)類型的其他詳細(xì)信息,限制和屬性,請(qǐng)參閱浮點(diǎn)類型的限制和math.h庫(kù)。

復(fù)雜的浮動(dòng)類型

復(fù)數(shù)浮點(diǎn)類型對(duì)數(shù)學(xué)復(fù)數(shù)進(jìn)行建模,即可以寫成實(shí)數(shù)和實(shí)數(shù)乘以虛數(shù)單位的和的數(shù)字:a + bi

三種復(fù)雜類型是

  • float _Complex(也可以像float complex包含<complex.h>一樣使用)

  • double _Complex(也可以像double complex包含<complex.h>一樣使用)

  • long double _Complex(也可以像long double complex包含<complex.h>一樣使用)

注意:與所有類型說明符一樣,可以使用任何順序:long double complexcomplex long double甚至double complex long命名相同的類型。

運(yùn)行此代碼

#include <complex.h>#include <stdio.h>int main(void){
    double complex z = 1 + 2*I;
    z = 1/z;    printf("1/(1.0+2.0i) = %.1f%+.1fi\n", creal(z), cimag(z));}

輸出:

1/(1.0+2.0i) = 0.2-0.4i

如果宏常量__STDC_NO_COMPLEX__(C11)由實(shí)現(xiàn)定義,<complex.h>則不提供復(fù)雜類型(以及庫(kù)標(biāo)題)。(自C11以來)

每個(gè)復(fù)雜類型具有相同的對(duì)象表示和對(duì)準(zhǔn)要求作為一個(gè)陣列對(duì)應(yīng)的真實(shí)類型的兩個(gè)元件(的浮動(dòng)為float compelx,double為double complex,long double為long double complex)。數(shù)組的第一個(gè)元素保存實(shí)數(shù)部分,數(shù)組的第二個(gè)元素保存虛數(shù)部分。


float a[4] = {1, 2, 3, 4};float complex z1, z2;memcpy(&z1, a, sizeof z1); // z1 becomes 1.0 + 2.0imemcpy(&z2, a+2, sizeof z2); // z2 becomes 3.0 + 4.0i

復(fù)數(shù)可能與算術(shù)運(yùn)算符+  - 和*一起使用,可能與虛數(shù)和實(shí)數(shù)混合使用。在complex.h中為復(fù)數(shù)定義了許多數(shù)學(xué)函數(shù)。內(nèi)置運(yùn)算符和庫(kù)函數(shù)都可能會(huì)引發(fā)浮點(diǎn)異常并errno按照math_errhandling中所述進(jìn)行設(shè)置。

沒有為復(fù)雜類型定義增量和減量。

沒有為復(fù)雜類型定義關(guān)系運(yùn)算符(沒有“小于”的概念)在復(fù)雜類型和其他算術(shù)類型之間定義隱式轉(zhuǎn)換。

為了支持復(fù)數(shù)運(yùn)算的單一無(wú)窮大模型,C 將具有至少一個(gè)無(wú)限部分的任何復(fù)數(shù)值視為無(wú)窮大,即使其另一部分是 NaN,也保證所有運(yùn)算符和函數(shù)都遵守入口的基本屬性并提供cproj將所有無(wú)窮大映射到規(guī)范的一個(gè)(請(qǐng)參閱算術(shù)運(yùn)算符以了解確切的規(guī)則)。

運(yùn)行此代碼

#include <stdio.h>#include <complex.h>#include <math.h>int main(void){
   double complex z = (1 + 0*I) * (INFINITY + I*INFINITY);// textbook formula would give// (1+i0)(∞+i∞) ? (1×∞ – 0×∞) + i(0×∞+1×∞) ? NaN + I*NaN// but C gives a complex infinity   printf("%f + i*%f\n", creal(z), cimag(z)); // textbook formula would give// cexp(∞+iNaN) ? exp(∞)×(cis(NaN)) ? NaN + I*NaN// but C gives  ±∞+i*nan
   double complex y = cexp(INFINITY + I*NAN);   printf("%f + i*%f\n", creal(y), cimag(y));

可能的輸出:

inf + i*inf 
inf + i*nan

C 盡管存在笛卡爾表示的內(nèi)在局限性,但它也可以處理多個(gè)無(wú)窮大,以盡可能地保留方向信息:

將虛數(shù)單位乘以實(shí)無(wú)窮大給出正確簽名的虛無(wú)限:i×∞=i∞。另外,i×(∞-i∞)=∞+i∞表示合理的象限。

虛浮點(diǎn)類型

虛浮點(diǎn)類型對(duì)數(shù)學(xué)虛數(shù)進(jìn)行建模,即可以寫成實(shí)數(shù)乘以虛數(shù)單位的數(shù)字:bi 三個(gè)虛構(gòu)類型。

  • float _Imaginary(也可以像float imaginary包含<complex.h>一樣使用)

  • double _Imaginary(也可以像double imaginary包含<complex.h>一樣使用)

  • long double _Imaginary(也可以像long double imaginary包含<complex.h>一樣使用)

注意:與所有類型說明符一樣,可以使用任何順序:long double imaginary,imaginary long double甚至double imaginary long命名相同的類型。

#include <complex.h>#include <stdio.h>int main(void){
    double imaginary z = 3*I;
    z = 1/z;    printf("1/(3.0i) = %+.1fi\n", cimag(z));}

輸出:

1/(3.0i) = -0.3i

建議定義__STDC_IEC_559_COMPLEX__的編譯器,但不要求支持虛數(shù)。POSIX建議檢查宏_Imaginary_I是否被定義為標(biāo)識(shí)虛數(shù)支持。(自C99開始)(直到C11)

如果__STDC_IEC_559_COMPLEX__定義了虛數(shù),則支持虛數(shù)。(自 C11開始)

三種虛構(gòu)類型中的每一種都具有與其對(duì)應(yīng)的真實(shí)類型(float float imaginarydouble double imaginary,long double long double imaginary)相同的對(duì)象表示和對(duì)齊要求。

注意:盡管如此,虛構(gòu)類型是不同的,并且與它們相應(yīng)的真實(shí)類型不兼容,這就禁止了別名。

虛數(shù)可以與算術(shù)運(yùn)算符+  - 和*一起使用,可能與復(fù)數(shù)和實(shí)數(shù)混合使用。在complex.h中為虛數(shù)定義了許多數(shù)學(xué)函數(shù)。內(nèi)置運(yùn)算符和庫(kù)函數(shù)都可能會(huì)引發(fā)浮點(diǎn)異常并errno按照中所述進(jìn)行設(shè)置math_errhandling。

沒有為虛數(shù)類型定義增量和減量隱式轉(zhuǎn)換是在虛數(shù)類型和其他算術(shù)類型之間定義的。

虛數(shù)使得使用自然符號(hào)表示所有復(fù)數(shù)x + I*y(它I被定義為_Imaginary_I)成為可能。沒有虛構(gòu)的類型,某些特殊的復(fù)雜值不能自然創(chuàng)建。例如,如果I定義為_Complex_I,則寫入0.0 + I*INFINITY將 NaN 作為實(shí)部,并且CMPLX(0.0, INFINITY)必須使用 NaN 。具有負(fù)零虛數(shù)分量的數(shù)字也是如此,當(dāng)使用分支切分處理庫(kù)函數(shù)時(shí)這些數(shù)字是有意義的,例如csqrt1.0 - 0.0*I如果I定義為正零零虛數(shù)分量,_Complex_I并且負(fù)零虛數(shù)部分需要使用CMPLXconj。

虛構(gòu)類型也簡(jiǎn)化了實(shí)現(xiàn); 如果虛數(shù)類型得到支持,則可以用兩次乘法直接實(shí)現(xiàn)虛數(shù)與復(fù)數(shù)的乘法,而不是四次乘法和兩次加法。

(since C99)

關(guān)鍵詞

char, int, short, long, signed, unsigned, float, double. _Bool, _Complex, _Imaginary.

值的范圍

下表提供了常用數(shù)字表示限制的參考。由于 C 標(biāo)準(zhǔn)允許任何帶符號(hào)的整數(shù)表示,因此該表給出了最小保證需求(對(duì)應(yīng)于補(bǔ)碼的限制或符號(hào)和幅度)以及最常用的實(shí)現(xiàn)的限制,即二進(jìn)制補(bǔ)碼。不過,所有流行的數(shù)據(jù)模型(包括 ILP32,LP32,LP64,LLP64)都使用二進(jìn)制補(bǔ)碼表示法。

類型

大小以位為單位

格式

值范圍


近似

精確值




字符

8

signed (補(bǔ)充)

-127至127


signed (二補(bǔ))

-128至127




無(wú)符號(hào)

0到255




積分

16

signed (補(bǔ)充)

± 3.27 · 104

-32767至32767

signed (二補(bǔ))

-32768至32767




無(wú)符號(hào)

0至6.55·104

0至65535



32

signed (補(bǔ)充)

± 2.14 · 109

-2,147,483,647至2,147,483,647


signed (二補(bǔ))

-2,147,483,648至2,147,483,647




無(wú)符號(hào)

0至4.29·109

0至4,294,967,295



64

signed (補(bǔ)充)

± 9.22 · 1018

-9,223,372,036,854,775,807至9,223,372,036,854,775,807


signed (二補(bǔ))

-9,223,372,036,854,775,808至9,223,372,036,854,775,807




unsigned

0到1.84·1019

0至18,446,744,073,709,551,615



浮點(diǎn)

32

IEEE-754

±3.4·10±38(?7位)

min低于正常值:±1.401,298,4·10-47分鐘正常值:±1.175,494.3·10-38最高值:±3.402,823,4.1038

64

IEEE-754

±1.7·10±308(?15位)

min低于正常值:±4.940,656,458,412·10-324分鐘正常值:±2.225,073,858,507,201,4·10-308最大值:±1.797,693,134,862,315,7·10308


  • 次正常:±1,401,298.4·10-47

  • 分鐘正常值:±1.175,494.3·10-38

  • 最大值:±3.402,823,4.1038

 64   IEEE-754   **± 1.7 · 10± 308**

(~15 digits)

  • 次正常分:±4,940,656,458,412·10-324

  • 分鐘正常值:±2.225,073,858,507,201,4·10-308

  • 最大:±1.797,693,134,862,315,7·10308

注意:庫(kù)頭文件<limits.h>和<float.h>中提供了實(shí)際的(而不是保證的最小值)范圍

上一篇: 下一篇: