반복자를 포함하여 std :: string의 기능을 모방하는 문자열 클래스의 간단한 사용자 정의 가능한 구현.
using size_type = size_t; // size_type for positions of char in cstring
using const_pointer = const_iterator;
using pointer = iterator;
using const_reverse_pointer = const_reverse_iterator;
using reverse_pointer = reverse_iterator;
String(); // default constructor
String(const String &); // copy constructor
String(const String& other, size_type pos, size_t len = npos); // substring constructor
String(String &&); // move constructor
String(const char *); // from c-string
String(const char* s, size_t n); // from buffer
String(size_t n, char c);// fill constructor
String(const const_iterator first, const const_iterator second); // range constructor
String & operator= (const String &); // copy assignment
String & operator = (String &&); // move assignment
~String();
반복자/const_iterator를 첫 번째 문자로 반환합니다
iterator begin();
const_iterator begin() const;
문자열의 과거 말 캐릭터를 가리키는 Ierator/Const_iterator를 반환합니다
iterator end();
const_iterator end() const;
문자열의 첫 번째 캐릭터 / 과거-끝 캐릭터를 가리키는 const_iterator를 반환합니다.
const_iterator cbegin() const;
const_iterator cend() const;
reverse_iterator/const_reverse_iterator를 마지막 문자로 반환합니다
reverse_iterator rbegin();
const_reverse_iterator rbegin() const;
reverse_iterator/const_reverse_iterator를 반환합니다.
reverse_iterator rend();
const_reverse_iterator rend() const;
마지막 문자를 가리키는 const_reverse_iterator를 반환합니다.
const_reverse_iterator crbegin() const;
const_reverse_iterator crend() const;
문자열의 문자를 얻으십시오
const char & operator [] (size_type) const;
char & operator [] (size_type);
문자열로 문자를 얻으십시오
const char & at(size_type) const;
char & at(size_type);
첫 번째 캐릭터에 액세스하십시오
const char & front() const;
char & front();
마지막 캐릭터에 액세스하십시오
const char & back() const;
char & back();
문자열에 추가하십시오
String & operator += (const String &); // string (1)
String & operator += (const char *); // c - string (2)
String & operator += (char); // char (3)
문자열에 추가하십시오
String& append(const String& str); // string (1)
String& append(const String& str, size_type subpos, size_t sublen = npos); // substring (2)
String& append(const char* s); // c - string (3)
String& append(const char* s, size_t n); // buffer(4)
String& append(size_type n, char c); // fill(5)
String& append(const const_iterator first, const const_iterator second); // range(6)
String & push_back(char);
문자열에 삽입하십시오
String& insert(size_type pos, const String& other); // string(1)
String& insert(size_type pos, const String& other, size_type subpos, size_t sublen = npos); // substring(2)
String& insert(size_type pos, const char* other); // c - string(3)
String& insert(size_type pos, const char* s, size_t n); // buffer(4)
String& insert(size_type pos, size_t n, char c); // fill(5)
void insert(iterator p, size_t n, char c); // fill(6)
iterator insert(iterator p, char c); // single character(7)
void insert(iterator p, const const_iterator first, const const_iterator last); // range(8)
문자열에서 문자를 지우십시오
String& erase(size_type pos = 0, size_t len = npos); // sequence(1)
iterator erase(const_iterator p); // character(2)
iterator erase(const_iterator first, const_iterator last); // range(3)
문자열 부분을 교체하십시오
String& replace(size_type pos, size_t len, const String& other); // string(1)
String& replace(const_iterator i1, const_iterator i2, const String& other); // string(2)
String& replace(size_type pos, size_t len, const String& other, size_type subpos, size_t sublen = npos); // substring(3)
String& replace(size_type pos, size_t len, const char* s); // c - string(4)
String& replace(const_iterator i1, const_iterator i2, const char* other); // c - string(5)
String& replace(size_type pos, size_t len, const char* other, size_t n); // buffer(6)
String& replace(const_iterator i1, const_iterator i2, const char* other, size_t n); // buffer(7)
String& replace(size_type pos, size_t len, size_t n, char c); // fill(8)
String& replace(const_iterator i1, const_iterator i2, size_type n, char c); // fill(9)
String& replace(const_iterator i1, const_iterator i2, const_iterator first, const_iterator second); // range(10)
문자열 값을 바꾸십시오
void swap(String &);
마지막 문자를 삭제하십시오
String & pop_back();
C 문자열을 동등하게 얻습니다
const char * c_str() const;
문자열에서 문자 순서를 복사합니다
size_t copy(char* s, size_t len, size_type pos = 0) const;
문자열에서 내용을 찾으십시오
size_type find(const String& other, size_type pos = 0) const; //string(1)
size_type find(const char* s, size_type pos = 0) const; // c - string(2)
size_type find(const char* s, size_type pos, size_type n) const; // buffer(3)
size_type find(char c, size_type pos = 0) const; // character(4)
문자열에서 마지막으로 컨텐츠가 발생합니다
size_type rfind(const String& other, size_type pos = npos) const; // string(1)
size_type rfind(const char* s, size_type pos = npos) const; // c - string(2)
size_type rfind(const char* s, size_type pos, size_t n) const; // buffer(3)
size_type rfind(char c, size_type pos = npos) const; // character(4)
문자열에서 문자를 찾으십시오
size_type find_first_of(const String& other, size_type pos = 0) const; // string(1)
size_type find_first_of(const char* other, size_type pos = 0) const; // c - string(2)
size_type find_first_of(const char* other, size_type pos, size_t n) const; // buffer(3)
size_type find_first_of(char c, size_type pos = 0) const; // character(4)
끝에서 문자열로 문자를 찾으십시오
size_type find_last_of(const String& other, size_type pos = String::npos) const; // string(1)
size_type find_last_of(const char* other, size_type pos = String::npos) const; // c - string(2)
size_type find_last_of(const char* other, size_type pos, size_t n) const; // buffer(3)
size_type find_last_of(char c, size_type pos = String::npos) const; // character(4)
문자열에서 문자가없는 것을 찾으십시오
size_type find_first_not_of(const String& other, size_type pos = 0) const; // string(1)
size_type find_first_not_of(const char* other, size_type pos = 0) const; // c - string(2)
size_type find_first_not_of(const char* other, size_type pos, size_t n) const; // buffer(3)
size_type find_first_not_of(char c, size_type pos = 0) const; // character(4)
끝에서 문자열에서 일치하지 않는 문자를 찾으십시오
size_type find_last_not_of(const String& other, size_type pos = String::npos) const; // string(1)
size_type find_last_not_of(const char* other, size_type pos = String::npos) const; // c - string(2)
size_type find_last_not_of(const char* other, size_type pos, size_t n) const; // buffer(3)
size_type find_last_not_of(char c, size_type pos = String::npos) const; // character(4)
서브 스트링을 생성하십시오
String substr(size_type pos = 0, size_t len = npos) const;
문자열의 길이를 반환합니다
size_t length() const;
size_t size() const;
문자열의 최대 크기를 반환합니다
size_t max_size() const;
문자열 크기를 조정하십시오
void resize(size_t n);
void resize(size_type n, char c);
할당 된 스토리지의 반환 크기
size_t capacity() const;
용량 변경을 요청하십시오
void reserve(size_t n = 0);
명확한 문자열
void clear();
Return True는 String이 비어 있습니다
bool empty() const;
적합하게 수축
void shrink_to_fit();
static const size_t npos = -1; // Maximum value for size_t
비교
// Size is compared and if equal then comapred lexicographically
friend bool operator == (const String &, const String &);
friend bool operator != (const String &, const String &);
friend bool operator < (const String &, const String &);
friend bool operator > (const String &, const String &);
friend bool operator <= (const String &, const String &);
friend bool operator >= (const String &, const String &);
두 줄의 값을 교환합니다
void swap(String& x, String& y);
연결된 문자열을 반환합니다
String operator+ (const String& lhs, const String& rhs);
String operator+ (const String& lhs, const char* rhs);
String operator+ (const char* lhs, const String& rhs);
String operator+ (const String& lhs, char rhs);
String operator+ (char lhs, const String& rhs);
스트림에 문자열을 삽입하십시오
std::ostream& operator<< (std::ostream& os, const _JD String& str);
스트림에서 끈을 추출하십시오
std::istream& operator>> (std::istream& is, _JD String& str);
스트림에서 문자열로 줄을 가져옵니다
std::istream& getline(std::istream& is, _JD String& str, char delim);
std::istream& getline(std::istream& is, _JD String& str);