前提・実現したいこと
C++の std::string の演算に関する質問です。 ある文字列に文字を追加していく処理において次の2つの方法があるかと思います(ほかにもあるかもしれませんが)。この2つの結果は同じであるので、中でやってる処理も同じだと思ってました(短絡的な考え方ですが。。。)。ただ、この2つの処理速度を比べてみると、かなりの違いがある事が分かりました(実験内容と結果)。
そこで、質問になります。具体的に、この2つの処理はどの様に違うのでしょうか?
ご教授いただければ幸いです。
・方法:PatternA
C++
1std::string PatternA 2PatternA = PatternA + "任意の文字列";
・方法:PatternB
C++
1std::string PatternB 2PatternB += "任意の文字列";
実験内容と結果
実験内容
C++
1#include <iostream> 2#include <chrono> 3 4int main() 5{ 6 std::chrono::system_clock::time_point TimePoint01, TimePoint02, TimePoint03; 7 8 std::string PatternA = "うを"; 9 std::string PatternB = "うを"; 10 unsigned int numAB = 10000; 11 12 TimePoint01 = std::chrono::system_clock::now(); 13 for (unsigned int a = 0; a < numAB; ++a){ 14 PatternA = PatternA + "ぉ"; 15 } 16 TimePoint02 = std::chrono::system_clock::now(); 17 for (unsigned int a = 0; a < numAB; ++a){ 18 PatternB += "ぉ"; 19 } 20 TimePoint03 = std::chrono::system_clock::now(); 21 22 std::cout << "\tPatternA\t: " << std::chrono::duration_cast<std::chrono::microseconds>(TimePoint02 - TimePoint01).count() << "\t(ms)" << std::endl; 23 std::cout << "\tPatternB\t: " << std::chrono::duration_cast<std::chrono::microseconds>(TimePoint03 - TimePoint02).count() << "\t(ms)" << std::endl; 24 25 if(PatternA == PatternB){ 26 std::cout << "\tPatternA == PatternB" << std::endl; 27 } 28 else { 29 std::cout << "\tPatternA != PatternB" << std::endl; 30 } 31 getchar(); 32}
実験結果
コンソールの表示
PatternA : 3018 (ms) PatternB : 19 (ms) PatternA == PatternB
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2021/08/18 01:34