C++ 运算符优先级

来源:互联网 发布:阿里云虚拟服务器 编辑:程序博客网 时间:2024/05/21 14:47

http://en.cppreference.com/w/cpp/language/operator_precedence


The following table lists the precedence and associativity of C++ operators. Operators are listed top to bottom, in descending precedence.

PrecedenceOperatorDescriptionAssociativity1::Scope resolutionLeft-to-right2++   --Suffix/postfix increment and decrement (a++)()Function call[]Array subscripting.Element selection by reference−>Element selection through pointer3++   --Prefix increment and decrement (++a)Right-to-left+   Unary plus and minus!   ~Logical NOT and bitwise NOT(type)Type cast*Indirection (dereference)&Address-ofsizeofSize-ofnewnew[]Dynamic memory allocationdeletedelete[]Dynamic memory deallocation4.*   ->*Pointer to memberLeft-to-right5*   /   %Multiplication, division, and remainder6+   Addition and subtraction7<<   >>Bitwise left shift and right shift8<   <=For relational operators < and ≤ respectively>   >=For relational operators > and ≥ respectively9==   !=For relational = and ≠ respectively10&Bitwise AND11^Bitwise XOR (exclusive or)12|Bitwise OR (inclusive or)13&&Logical AND14||Logical OR15?:Ternary conditionalRight-to-left=Direct assignment (provided by default for C++ classes)+=   −=Assignment by sum and difference*=   /=   %=Assignment by product, quotient, and remainder<<=   >>=Assignment by bitwise left shift and right shift&=   ^=   |=Assignment by bitwise AND, XOR, and OR16throwThrow operator (for exceptions)17,CommaLeft-to-right

When parsing an expression, an operator which is listed on some row will be bound tighter (as if by parentheses) to its arguments than any operator that is listed on a row further below it. For example, the expressions std::cout<<a&b and *p++ are parsed as (std::cout<<a)&b and *(p++), and not asstd::cout<<(a&b) or (*p)++.

Operators that are in the same cell (there may be several rows of operators listed in a cell) are evaluated with the same precedence, in the given direction. For example, the expression a=b=c is parsed as a=(b=c), and not as (a=b)=c because of right-to-left associativity.

An operator's precedence is unaffected by overloading.