C++ åèæå
- C++11
- C++14
- C++17
- C++20
- C++ ç¼è¯å¨æ¯ææ åµè¡¨
- ç¬ç«ä¸å®¿ä¸»å®ç°
- C++ è¯è¨
- C++ å ³é®è¯
- é¢å¤çå¨
- C++ æ ååºå¤´æä»¶
- å ·åè¦æ±
- åè½ç¹æ§æµè¯ (C++20)
- å·¥å ·åº
- ç±»åæ¯æï¼åºæ¬ç±»åãRTTIãç±»åç¹æ§ï¼
- æ¦å¿µåº (C++20)
- é误å¤ç
- 卿å å管ç
- æ¥æåæ¶é´å·¥å ·
- å符串åº
- 容å¨åº
- è¿ä»£å¨åº
- èå´åº (C++20)
- ç®æ³åº
- æ°å¼åº
- å¸¸ç¨æ°å¦å½æ°
- æ°å¦ç¹æ®å½æ°
- ä¼ªéæºæ°çæ
- æµ®ç¹ç¯å¢
- std::complex
- std::complex<T>::complex
- std::complex<T>::operator=
- std::complex<T>::real
- std::literals::complex_literals::operator""i, operator""if, operator""il
- std::complex<T>::imag
- std::complex<T>::operator+=,-=,*=,/=
- std::complex<T>::operator+(unary), operator-(unary)
- operator+,-,*,/ (std::complex)
- operator==,!=(std::complex)
- operator<<,>>(std::complex)
- std::real(std::complex)
- std::imag(std::complex)
- std::abs(std::complex)
- std::arg(std::complex)
- std::norm(std::complex)
- std::conj(std::complex)
- std::proj(std::complex)
- std::polar(std::complex)
- std::exp(std::complex)
- std::log(std::complex)
- std::log10(std::complex)
- std::pow(std::complex)
- std::sqrt(std::complex)
- std::sin(std::complex)
- std::cos(std::complex)
- std::tan(std::complex)
- std::asin(std::complex)
- std::acos(std::complex)
- std::atan(std::complex)
- std::sinh(std::complex)
- std::cosh(std::complex)
- std::tanh(std::complex)
- std::asinh(std::complex)
- std::acosh(std::complex)
- std::atanh(std::complex)
- std::midpoint
- std::lerp
- std::has_single_bit
- std::bit_ceil
- std::bit_floor
- std::bit_width
- std::rotl
- std::valarray
- ç¼è¯æ¶æçæ°ç®æ¯
- std::gcd
- std::lcm
- æ°å¦å¸¸æ°
- std::bit_cast
- std::rotr
- std::countl_zero
- std::countl_one
- std::countr_zero
- std::countr_one
- std::popcount
- 注é
- è¾å ¥/è¾åºåº
- æä»¶ç³»ç»åº
- æ¬å°ååº
- æ£å表达å¼åº
- ååæä½åº
- çº¿ç¨æ¯æåº
- å®éªæ§ C++ ç¹æ§
- æç¨çèµæº
- ç´¢å¼
- std 符å·ç´¢å¼
- åç¨æ¯æ (C++20)
- C++ å ³é®è¯
ä½ç½®ï¼é¦é¡µ > C++ åèæå >æ°å¼åº >std::complex > operator+,-,*,/ (std::complex)
operator+,-,*,/ (std::complex)
ä¸ºå¤æ°è¿ç®åæ··å夿°/æ éè¿ç®å®ç°äºå è¿ç®ç¬¦ãå°æ éå½åæ¥æçäºåæ°çå®é¨å设为é¶çèé¨ç夿°ã
1-3) è¿åå
¶åæ°çå
4-6) è¿åä»
lhs åå» rhs çç»æ7-9) å°åæ°ç¸ä¹
10-12)
lhs é¤ä»¥ rhsåæ°
| lhs, rhs | - | åæ°ï¼ä¸¤ä¸ªå¤æ°ï¼æä¸ä¸ªå¤æ°ä¸ä¸ä¸ªæ¥æå¹é ç±»åçæ éï¼ float ã double ã long double ï¼ |
è¿åå¼
1-3) std::complex<T>(lhs) += rhs
4-6) std::complex<T>(lhs) -= rhs
7-9) std::complex<T>(lhs) *= rhs
10-12) std::complex<T>(lhs) /= rhs
注æ
模æ¿å®åæ¨å¯¼ä¸èèéå¼è½¬æ¢ï¼æ è¿äºè¿ç®ç¬¦ä¸è½ç¨äºæ´æ°/夿°æ··åè¿ç®ãæææ åµä¸ï¼æ éå¿ é¡»ä¸å¤æ°çåºå±ç±»åæ¥æç¸åç±»åã
GCC æ å¿ "-fcx-limited-range" ï¼å å«äº "-ffast-math" ï¼æ´æ¹å¤æ°ä¹/é¤çè¡ä¸ºï¼ç§»é¤æµ®ç¹æç«¯æ åµçæ£æ¥ãè¿ä¼å½±ååéåã
示ä¾
è¿è¡æ¤ä»£ç
#include <iostream> #include <complex> int main() { std::complex<double> c2(2, 0); std::complex<double> ci(0, 1);  std::cout << ci << " + " << c2 << " = " << ci+c2 << '\n' << ci << " * " << ci << " = " << ci*ci << '\n' << ci << " + " << c2 << " / " << ci << " = " << ci+c2/ci << '\n' << 1 << " / " << ci << " = " << 1./ci << '\n';  // std::cout << 1.f/ci; // ç¼è¯é误 // std::cout << 1/ci; // ç¼è¯é误 }
è¾åºï¼
(0,1) + (2,0) = (2,1) (0,1) * (0,1) = (-1,0) (0,1) + (2,0) / (0,1) = (0,-1) 1 / (0,1) = (0,-1)
åé
| ä¸¤ä¸ªå¤æ°ï¼æä¸ä¸ªå¤æ°ä¸ä¸ä¸ªæ éçå¤åèµå¼ (å ¬å¼æå彿°) | |
| 坹夿°è¿ç¨ä¸å
è¿ç®ç¬¦ (彿°æ¨¡æ¿) |