Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1373)

Side by Side Diff: base/metrics/sample_map.h

Issue 11022002: Add SampleMap and use it in SparseHistogram (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Add destructors to avoid compiler warning on clang Created 8 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 // SampleVector implements HistogramSamples interface. It is used by all 5 // SampleVector implements HistogramSamples interface. It is used by all
Ilya Sherman 2012/10/01 21:24:50 nit: SampleMap
kaiwang 2012/10/01 22:38:52 Done.
6 // Histogram based classes to store samples. 6 // SparseHistogram to store samples.
Ilya Sherman 2012/10/01 21:24:50 Optional nit: For the second sentence, perhaps som
kaiwang 2012/10/01 22:38:52 Done.
7 7
8 #ifndef BASE_METRICS_SAMPLE_VECTOR_H_ 8 #ifndef BASE_METRICS_SAMPLE_MAP_H_
9 #define BASE_METRICS_SAMPLE_VECTOR_H_ 9 #define BASE_METRICS_SAMPLE_MAP_H_
10 10
11 #include <vector> 11 #include <map>
12 12
13 #include "base/compiler_specific.h" 13 #include "base/compiler_specific.h"
14 #include "base/gtest_prod_util.h"
15 #include "base/memory/scoped_ptr.h" 14 #include "base/memory/scoped_ptr.h"
16 #include "base/metrics/histogram_base.h" 15 #include "base/metrics/histogram_base.h"
17 #include "base/metrics/histogram_samples.h" 16 #include "base/metrics/histogram_samples.h"
17 #include "base/synchronization/lock.h"
18 18
19 namespace base { 19 namespace base {
20 20
21 class BucketRanges; 21 class BASE_EXPORT_PRIVATE SampleMap : public HistogramSamples {
22
23 class BASE_EXPORT_PRIVATE SampleVector : public HistogramSamples {
24 public: 22 public:
25 explicit SampleVector(const BucketRanges* bucket_ranges); 23 SampleMap();
26 virtual ~SampleVector(); 24 virtual ~SampleMap();
27 25
28 // HistogramSamples implementation: 26 // HistogramSamples implementation:
29 virtual void Accumulate(HistogramBase::Sample value, 27 virtual void Accumulate(HistogramBase::Sample value,
30 HistogramBase::Count count) OVERRIDE; 28 HistogramBase::Count count) OVERRIDE;
31 virtual HistogramBase::Count GetCount( 29 virtual HistogramBase::Count GetCount(
32 HistogramBase::Sample value) const OVERRIDE; 30 HistogramBase::Sample value) const OVERRIDE;
33 virtual HistogramBase::Count TotalCount() const OVERRIDE; 31 virtual HistogramBase::Count TotalCount() const OVERRIDE;
34 virtual scoped_ptr<SampleCountIterator> Iterator() const OVERRIDE; 32 virtual scoped_ptr<SampleCountIterator> Iterator() const OVERRIDE;
35 33
36 // Get count of a specific bucket.
37 HistogramBase::Count GetCountAtIndex(size_t bucket_index) const;
38
39 protected: 34 protected:
40 virtual bool AddSubtractImpl( 35 virtual bool AddSubtractImpl(
41 SampleCountIterator* iter, 36 SampleCountIterator* iter,
42 HistogramSamples::Instruction instruction) OVERRIDE; 37 HistogramSamples::Instruction instruction) OVERRIDE;
43 38
44 virtual size_t GetBucketIndex(HistogramBase::Sample value) const; 39 private:
40 std::map<HistogramBase::Sample, HistogramBase::Count> sample_count_;
Ilya Sherman 2012/10/01 21:24:50 nit: I think either |sample_counts_| or just |coun
kaiwang 2012/10/01 22:38:52 Done.
45 41
46 private: 42 // Protects access to above map.
47 FRIEND_TEST_ALL_PREFIXES(HistogramTest, CorruptSampleCounts); 43 mutable base::Lock lock_;
Ilya Sherman 2012/10/01 21:24:50 This is tangential to the current CL, but I wonder
kaiwang 2012/10/01 22:38:52 At least for existing histograms, it's common to b
48 44
49 std::vector<HistogramBase::Count> counts_; 45 DISALLOW_COPY_AND_ASSIGN(SampleMap);
50
51 // Shares the same BucketRanges with Histogram object.
52 const BucketRanges* const bucket_ranges_;
53
54 DISALLOW_COPY_AND_ASSIGN(SampleVector);
55 }; 46 };
56 47
57 class BASE_EXPORT_PRIVATE SampleVectorIterator : public SampleCountIterator { 48 class BASE_EXPORT_PRIVATE SampleMapIterator : public SampleCountIterator {
58 public: 49 public:
59 SampleVectorIterator(const std::vector<HistogramBase::Count>* counts, 50 SampleMapIterator(
60 const BucketRanges* bucket_ranges); 51 const std::map<HistogramBase::Sample, HistogramBase::Count>&
52 sample_count);
Ilya Sherman 2012/10/01 21:24:50 nit: Same naming comment as above.
kaiwang 2012/10/01 22:38:52 Done.
53
54 virtual ~SampleMapIterator();
61 55
62 // SampleCountIterator implementation: 56 // SampleCountIterator implementation:
63 virtual bool Done() const OVERRIDE; 57 virtual bool Done() const OVERRIDE;
64 virtual void Next() OVERRIDE; 58 virtual void Next() OVERRIDE;
65 virtual void Get(HistogramBase::Sample* min, 59 virtual void Get(HistogramBase::Sample* min,
66 HistogramBase::Sample* max, 60 HistogramBase::Sample* max,
67 HistogramBase::Count* count) const OVERRIDE; 61 HistogramBase::Count* count) const OVERRIDE;
68 virtual bool GetBucketIndex(size_t* index) const OVERRIDE;
69
70 private: 62 private:
71 void SkipEmptyBuckets(); 63 std::map<HistogramBase::Sample, HistogramBase::Count>::const_iterator iter_;
72 64 const std::map<HistogramBase::Sample, HistogramBase::Count>::const_iterator
73 const std::vector<HistogramBase::Count>* counts_; 65 end_;
74 const BucketRanges* bucket_ranges_;
75
76 size_t index_;
77 }; 66 };
78 67
79 } // namespace base 68 } // namespace base
80 69
81 #endif // BASE_METRICS_SAMPLE_VECTOR_H_ 70 #endif // BASE_METRICS_SAMPLE_MAP_H_
OLDNEW
« no previous file with comments | « base/base.gypi ('k') | base/metrics/sample_map.cc » ('j') | base/metrics/sample_map.cc » ('J')

Powered by Google App Engine
This is Rietveld 408576698