📄 sstring.h
字号:
// File from page 603 in "Thinking in C++" by Bruce Eckel
//////////////////////////////////////////////////
// From the compressed package ECKELT02.ZIP 4/11/95
// (Original ECKELT01.ZIP dated 2/21/95)
// Copyright (c) Bruce Eckel, 1995
// Source code file from the book "Thinking in C++",
// Prentice Hall, 1995, ISBN: 0-13-917709-4
// All rights reserved EXCEPT as allowed by the following
// statements: You may freely use this file for your own
// work, including modifications and distribution in
// executable form only. You may copy and distribute this
// file, as long as it is only distributed in the complete
// (compressed) package with the other files from this
// book and you do not remove this copyright and notice.
// You may not distribute modified versions of the source
// code in this package. This package may be freely placed
// on bulletin boards, internet nodes, shareware disks and
// product vendor disks. You may not use this file in
// printed media without the express permission of the
// author. Bruce Eckel makes no
// representation about the suitability of this software
// for any purpose. It is provided "as is" without express
// or implied warranty of any kind. The entire risk as to
// the quality and performance of the software is with
// you. Should the software prove defective, you assume
// the cost of all necessary servicing, repair, or
// correction.
// If you think you've found an error, please
// email all modified files with loudly commented changes
// to: eckel@aol.com (please use the same
// address for non-code errors found in the book).
//////////////////////////////////////////////////
//: SSTRING.H -- Stack-based string
#ifndef SSTRING_H_
#define SSTRING_H_
#include <string.h>
#include <iostream.h>
template<int bsz = 0>
class SString {
char buf[bsz + 1];
char* s;
public:
SString(const char* S = "") : s(buf) {
if(!bsz) { // Make on heap
s = new char[strlen(S) + 1];
strcpy(s, S);
} else { // Make on stack
buf[bsz] = 0; // Ensure 0 termination
strncpy(s, S, bsz);
}
}
SString(const SString& rv) : s(buf) {
if(!bsz) { // Make on heap
s = new char[strlen(rv.s) + 1];
strcpy(s, rv.s);
} else { // Make on stack
buf[bsz] = 0;
strncpy(s, rv.s, bsz);
}
}
SString& operator=(const SString& rv) {
// Check for self-assignment:
if(&rv == this) return *this;
if(!bsz) { // Manage heap:
delete s;
s = new char[strlen(rv.s) + 1];
}
// Constructor guarantees length < bsz:
strcpy(s, rv.s);
return *this;
}
~SString() {
if(!bsz) delete []s;
}
int operator==(const SString& rv) const {
return !stricmp(s, rv.s);
}
int operator!=(const SString& rv) const {
return stricmp(s, rv.s);
}
int operator>(const SString& rv) const {
return stricmp(s, rv.s) > 0;
}
int operator<(const SString& rv) const {
return stricmp(s, rv.s) < 0;
}
char* str() const { return s; }
friend ostream&
operator<<(ostream& os,
const SString<bsz>& S) {
return os << S.s;
}
};
typedef SString<> Hstring; // Heap string
#endif // SSTRING_H_
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -