OSDN Git Service

e385eb752b2142ab52f7879a35aceebbec6af09f
[pf3gnuchains/gcc-fork.git] / libstdc++-v3 / testsuite / performance / string_append.cc
1  // Copyright (C) 2003 Free Software Foundation, Inc.
2 //
3 // This file is part of the GNU ISO C++ Library.  This library is free
4 // software; you can redistribute it and/or modify it under the
5 // terms of the GNU General Public License as published by the
6 // Free Software Foundation; either version 2, or (at your option)
7 // any later version.
8
9 // This library is distributed in the hope that it will be useful,
10 // but WITHOUT ANY WARRANTY; without even the implied warranty of
11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12 // GNU General Public License for more details.
13
14 // You should have received a copy of the GNU General Public License along
15 // with this library; see the file COPYING.  If not, write to the Free
16 // Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
17 // USA.
18
19 // As a special exception, you may use this file as part of a free software
20 // library without restriction.  Specifically, if other files instantiate
21 // templates or use macros or inline functions from this file, or you compile
22 // this file and link it with other files to produce an executable, this
23 // file does not by itself cause the resulting executable to be covered by
24 // the GNU General Public License.  This exception does not however
25 // invalidate any other reasons why the executable file might be covered by
26 // the GNU General Public License.
27
28 #include <ctime>
29 #include <iostream>
30 #include <string>
31
32 using namespace std;
33
34 void
35 test_append_char(int how_much)
36 {
37   string buf; // no preallocation
38   for (int i = 0; i < how_much; ++i)
39      buf.append(static_cast<string::size_type>(1) , 'x');
40 }
41
42 void
43 test_append_string(int how_much)
44 {
45   string s(static_cast<string::size_type>(1) , 'x');
46   string buf; // no preallocation
47   for (int i = 0; i < how_much; ++i)
48      buf.append(s);
49 }
50
51 void 
52 run_benchmark1(int how_much)
53 {
54   clock_t t0 = clock();
55   test_append_char(how_much);
56   clock_t t1 = clock();
57   cout << "Execution time of " << how_much
58        << " string::append(char) calls: " 
59        << (static_cast<float>(t1 - t0)/CLOCKS_PER_SEC) << " sec."<< endl;
60 }
61
62 void 
63 run_benchmark2(int how_much)
64 {
65   clock_t t0 = clock();
66   test_append_string(how_much);
67   clock_t t1 = clock();
68   cout << "Execution time of " << how_much
69        << " string::append(const string&) calls: " 
70        << (static_cast<float>(t1 - t0)/CLOCKS_PER_SEC) << " sec." << endl;
71 }
72
73 // libstdc++/5380
74 // libstdc++/4960
75 int main()
76 {
77   run_benchmark1(10000);
78   run_benchmark2(10000);
79   run_benchmark1(100000);
80   run_benchmark2(100000);
81   run_benchmark1(1000000);
82   run_benchmark2(1000000);
83 }