封装固定长度字符数组的模板容器类
代码下载链接: /Files/Apan/CP_FixedString.rar
近来,项目组中在很多地方频繁的使用固定长度的字符数组,由于各人的操作习惯不一样,可能要的结果一样,但过程不一致,有时,在书写过程中,可能会漏写致命的操作。基于这些原因,封装了一个固定长度字符数组的模板类容器,提供一些常用操作,如果需要更多的操作,可以使用STL里的算法。代码如下:
注意:由于,模板的参数是个常量,所以CP_String<10>test1和CP_String<16>test2是两种不同类型的对象,这样的操作CP_String<10>test1(test2)、test1=test2等是非法的,可以这样使用CP_String<10>test1(test2.begin())、test1=test2.begin()
希望对看过本篇文章的朋友有所帮助,如发现错误的地方,请指出,非常感谢!
后记:写完本片文章的第二天,感觉这样的操作CP_String<10>test1(test2)、test1=test2等是非法的,感觉不是很爽,用起来比较麻烦,经过一番的尝试,终于搞定,很是高兴。
拷贝构造函数、赋值函数等类似函数只需这样修改就可以:
1
template
<
size_type M
>
2 CP_String( const CP_String < M >& other)
3 {
4 stringCopy(other.begin());
5 }
2 CP_String( const CP_String < M >& other)
3 {
4 stringCopy(other.begin());
5 }
这是原来写法:
1
2 CP_String( const CP_String < N >& other)
3 {
4 stringCopy(other.begin());
5 }
2 CP_String( const CP_String < N >& other)
3 {
4 stringCopy(other.begin());
5 }
完整代码如下:
1
#ifndef _HZ_FIXSTRING_HEAD
2 #define _HZ_FIXSTRING_HEAD
3 /* *
4 CopyRight: (C) 2009 by caipan
5 Contents: Fixed buffer length strings
6 Email: [email protected]
7 */
8
9 #include < memory.h >
10
11 template < size_t N >
12 class CP_FixString
13 {
14 public :
15 typedef TCHAR value_type;
16 typedef TCHAR * pointer;
17 typedef const TCHAR * const_pointer;
18 typedef TCHAR * iterator;
19 typedef const TCHAR * const_iterator;
20 typedef TCHAR & reference;
21 typedef const TCHAR & const_reference;
22 typedef size_t size_type;
23 typedef ptrdiff_t difference_type;
24 typedef std::random_access_iterator_tag iterator_category;
25
26 private :
27 enum
28 {
29 max_length = N, // 表示字符串的最大长度,不包括_T('\0')
30 max_size = N + 1 // 容纳字符串的缓冲区大小
31 };
32
33 public :
34 CP_FixString()
35 {
36 m_nStrLength = 0 ;
37 memset(m_buf, 0 , sizeof (m_buf));
38 }
39
40 CP_FixString( const TCHAR * pData)
41 {
42 stringCopy(pData);
43 }
44
45 template < size_type M >
46 CP_FixString( const CP_FixString < M >& other)
47 {
48 stringCopy(other.begin());
49 }
50
51 public :
52 template < size_type M >
53 CP_FixString & operator = ( const CP_FixString < M > & other)
54 {
55 stringCopy(other.begin());
56 return * this ;
57 }
58
59 CP_FixString & operator = ( const TCHAR * pData)
60 {
61 stringCopy(pData);
62 return * this ;
63 }
64
65 CP_FixString & operator += ( const TCHAR * pData)
66 {
67 stringCat(pData);
68 return * this ;
69 }
70
71 template < size_type M >
72 CP_FixString & operator += ( const CP_FixString < M >& other)
73 {
74 stringCat(other.begin());
75 return * this ;
76 }
77
78 bool operator == ( const TCHAR * pData)
79 {
80 return ! _tcscmp(m_buf, pData);
81 }
82
83 template < size_type M >
84 bool operator == ( const CP_FixString < M >& other)
85 {
86 return ! _tcscmp(m_buf, other.begin());
87 }
88
89 reference operator [](size_type n)
90 {
91 n = n < max_length ? n : max_length;
92
93 return m_buf[n];
94 }
95
96 const_reference operator [] (size_type n) const
97 {
98 n = n < max_length ? n : max_length;
99
100 return m_buf[n];
101 }
102
103 public :
104 iterator begin()
105 {
106 return m_buf;
107 }
108
109 iterator end()
110 {
111 return m_buf + m_nStrLength + 1 ;
112 }
113
114 const_iterator begin() const
115 {
116 return m_buf;
117 }
118
119 const_iterator end() const
120 {
121 return m_buf + m_nStrLength + 1 ;
122 }
123
124 bool empty()
125 {
126 return m_buf[ 0 ] == _T( ' \0 ' );
127 }
128
129 void clear()
130 {
131 m_nStrLength = 0 ;
132 memset(m_buf, 0 , sizeof (m_buf));
133 }
134
135 size_type capacity() const
136 {
137 return max_length;
138 }
139
140 size_type size() const
141 {
142 return m_nStrLength;
143 }
144
145 size_type length() const
146 {
147 return m_nStrLength;
148 }
149
150 private :
151 void stringCopy( const TCHAR * pData)
152 {
153 memset(m_buf, 0 , sizeof (m_buf));
154
155 size_type nLen = _tcslen(pData);
156
157 nLen = nLen < max_length ? nLen : max_length;
158
159 _tcsncpy(m_buf, pData, nLen);
160
161 m_nStrLength = _tcslen(m_buf);
162 }
163
164 void stringCat( const TCHAR * pData)
165 {
166 size_type nDataLen = _tcslen(pData);
167 size_type nLen = length();
168 nLen = max_length - nLen;
169 nLen = nLen > nDataLen ? nDataLen : nLen;
170
171 _tcsncat(m_buf, pData, nLen);
172
173 m_nStrLength = _tcslen(m_buf);
174 }
175
176 private :
177 TCHAR m_buf[max_size];
178 size_type m_nStrLength;
179 };
180 #endif
2 #define _HZ_FIXSTRING_HEAD
3 /* *
4 CopyRight: (C) 2009 by caipan
5 Contents: Fixed buffer length strings
6 Email: [email protected]
7 */
8
9 #include < memory.h >
10
11 template < size_t N >
12 class CP_FixString
13 {
14 public :
15 typedef TCHAR value_type;
16 typedef TCHAR * pointer;
17 typedef const TCHAR * const_pointer;
18 typedef TCHAR * iterator;
19 typedef const TCHAR * const_iterator;
20 typedef TCHAR & reference;
21 typedef const TCHAR & const_reference;
22 typedef size_t size_type;
23 typedef ptrdiff_t difference_type;
24 typedef std::random_access_iterator_tag iterator_category;
25
26 private :
27 enum
28 {
29 max_length = N, // 表示字符串的最大长度,不包括_T('\0')
30 max_size = N + 1 // 容纳字符串的缓冲区大小
31 };
32
33 public :
34 CP_FixString()
35 {
36 m_nStrLength = 0 ;
37 memset(m_buf, 0 , sizeof (m_buf));
38 }
39
40 CP_FixString( const TCHAR * pData)
41 {
42 stringCopy(pData);
43 }
44
45 template < size_type M >
46 CP_FixString( const CP_FixString < M >& other)
47 {
48 stringCopy(other.begin());
49 }
50
51 public :
52 template < size_type M >
53 CP_FixString & operator = ( const CP_FixString < M > & other)
54 {
55 stringCopy(other.begin());
56 return * this ;
57 }
58
59 CP_FixString & operator = ( const TCHAR * pData)
60 {
61 stringCopy(pData);
62 return * this ;
63 }
64
65 CP_FixString & operator += ( const TCHAR * pData)
66 {
67 stringCat(pData);
68 return * this ;
69 }
70
71 template < size_type M >
72 CP_FixString & operator += ( const CP_FixString < M >& other)
73 {
74 stringCat(other.begin());
75 return * this ;
76 }
77
78 bool operator == ( const TCHAR * pData)
79 {
80 return ! _tcscmp(m_buf, pData);
81 }
82
83 template < size_type M >
84 bool operator == ( const CP_FixString < M >& other)
85 {
86 return ! _tcscmp(m_buf, other.begin());
87 }
88
89 reference operator [](size_type n)
90 {
91 n = n < max_length ? n : max_length;
92
93 return m_buf[n];
94 }
95
96 const_reference operator [] (size_type n) const
97 {
98 n = n < max_length ? n : max_length;
99
100 return m_buf[n];
101 }
102
103 public :
104 iterator begin()
105 {
106 return m_buf;
107 }
108
109 iterator end()
110 {
111 return m_buf + m_nStrLength + 1 ;
112 }
113
114 const_iterator begin() const
115 {
116 return m_buf;
117 }
118
119 const_iterator end() const
120 {
121 return m_buf + m_nStrLength + 1 ;
122 }
123
124 bool empty()
125 {
126 return m_buf[ 0 ] == _T( ' \0 ' );
127 }
128
129 void clear()
130 {
131 m_nStrLength = 0 ;
132 memset(m_buf, 0 , sizeof (m_buf));
133 }
134
135 size_type capacity() const
136 {
137 return max_length;
138 }
139
140 size_type size() const
141 {
142 return m_nStrLength;
143 }
144
145 size_type length() const
146 {
147 return m_nStrLength;
148 }
149
150 private :
151 void stringCopy( const TCHAR * pData)
152 {
153 memset(m_buf, 0 , sizeof (m_buf));
154
155 size_type nLen = _tcslen(pData);
156
157 nLen = nLen < max_length ? nLen : max_length;
158
159 _tcsncpy(m_buf, pData, nLen);
160
161 m_nStrLength = _tcslen(m_buf);
162 }
163
164 void stringCat( const TCHAR * pData)
165 {
166 size_type nDataLen = _tcslen(pData);
167 size_type nLen = length();
168 nLen = max_length - nLen;
169 nLen = nLen > nDataLen ? nDataLen : nLen;
170
171 _tcsncat(m_buf, pData, nLen);
172
173 m_nStrLength = _tcslen(m_buf);
174 }
175
176 private :
177 TCHAR m_buf[max_size];
178 size_type m_nStrLength;
179 };
180 #endif