ใน C ++ 11 เรามีไวยากรณ์ใหม่สำหรับการเริ่มต้นคลาสซึ่งทำให้เรามีความเป็นไปได้มากมายในการเริ่มต้นตัวแปร
{ // Example 1
int b(1);
int a{1};
int c = 1;
int d = {1};
}
{ // Example 2
std::complex<double> b(3,4);
std::complex<double> a{3,4};
std::complex<double> c = {3,4};
auto d = std::complex<double>(3,4);
auto e = std::complex<double>{3,4};
}
{ // Example 3
std::string a(3,'x');
std::string b{3,'x'}; // oops
}
{ // Example 4
std::function<int(int,int)> a(std::plus<int>());
std::function<int(int,int)> b{std::plus<int>()};
}
{ // Example 5
std::unique_ptr<int> a(new int(5));
std::unique_ptr<int> b{new int(5)};
}
{ // Example 6
std::locale::global(std::locale("")); // copied from 22.4.8.3
std::locale::global(std::locale{""});
}
{ // Example 7
std::default_random_engine a {}; // Stroustrup's FAQ
std::default_random_engine b;
}
{ // Example 8
duration<long> a = 5; // Stroustrup's FAQ too
duration<long> b(5);
duration<long> c {5};
}
สำหรับตัวแปรแต่ละตัวที่ฉันประกาศฉันต้องคิดว่าควรใช้ไวยากรณ์การเริ่มต้นตัวใดและสิ่งนี้ทำให้ความเร็วในการเข้ารหัสของฉันช้าลง ฉันแน่ใจว่านั่นไม่ใช่เจตนาที่จะแนะนำวงเล็บปีกกา
เมื่อพูดถึงรหัสเทมเพลตการเปลี่ยนไวยากรณ์อาจทำให้เกิดความหมายที่แตกต่างกันดังนั้นการไปในทางที่ถูกต้องจึงเป็นสิ่งสำคัญ
ฉันสงสัยว่ามีแนวทางสากลที่ควรเลือกไวยากรณ์หรือไม่