一个有用的ANSI字符串类String的实现及使用演示

下面的程序分成两个部分:

(1)String类:类头String.h和类实现String.cpp

(2)String类使用演示程序Main.cpp

 

类头文件String.h代码如下:

 

#ifndef STRING_H 
#define STRING_H 
#include <iostream> 
using namespace std;

class String 

    friend ostream & operator<<(ostream & output, const String & s); 
    friend istream & operator>>(istream & input, String & s);

public: 
    String(const char* = ""); 
    String(const String &); 
    ~String(); 
    const String & operator=(const String &);   //赋值 
    String & operator+=(const String &);        //字符串连接 
    int operator!() const;                      //String为空? 
    int operator==(const String &) const;       //测试s1==s2 
    int operator!=(const String &) const;       //测试s1!=s2 
    int operator<(const String &) const;        //测试s1<s2 
    int operator>(const String &) const;        //测试s1>s2 
    int operator<=(const String &) const;       //测试s1<=s2 
    int operator>=(const String &) const;       //测试s1>=s2 
    char & operator[](int);                     //返回对字符的引用 
    String & operator()(int, int);              //返回一个子字符串 
    int GetLength() const;                      //返回字符串的长度,不包括结尾的/0 
private: 
    char* sPtr;                                 //指向字符串起始位置的指针 
    int length;                                 //字符串的长度 
};

#endif
类实现文件String.cpp代码如下:

 

#include <iostream> 
#include <string.h> 
#include <assert.h> 
#include "String.h"

ostream & operator<<(ostream & output, const String & s) 

    output<<s.sPtr; 
    return output; 
}

istream & operator>>(istream & input, String & s) 

    static char temp[100]; 
    input>>temp; 
    s = temp; 
    return input; 
}

String::String(const char * s) 

    cout<<"Convention constructor:"<<s<<endl; 
    length = strlen(s); 
    sPtr = new char[length+1]; 
    assert(sPtr!=0); 
    strcpy(sPtr, s); 
}

String::String(const String & copy) 

    cout<<"Copy constructor:"<<copy.sPtr<<endl; 
    length = copy.length; 
    sPtr = new char[length+1]; 
    assert(sPtr != 0); 
    strcpy(sPtr, copy.sPtr); 
}

String::~String() 

    cout<<"Destructor:"<<sPtr<<endl; 
    delete[] sPtr; 
}

const String & String::operator=(const String & right) 

    cout<<"operator = called"<<endl; 
    if(&right != this)   //避免自我赋值 
    { 
        delete[] sPtr; 
        length = right.length; 
        sPtr = new char[length+1]; 
        assert(sPtr!=0); 
        strcpy(sPtr, right.sPtr); 
    } 
    else 
    { 
        cout<<"Attempt assignment of a String to itself/n"; 
    } 
    return *this; 
}

String & String::operator+=(const String & right) 

    char* tempPtr = sPtr; 
    length += right.length; 
    sPtr = new char[length+1]; 
    assert(sPtr!=0); 
    strcpy(sPtr, tempPtr); 
    strcat(sPtr, right.sPtr); 
    delete[] tempPtr; 
    return *this; 
}

//字符串为空? 
int String::operator !() const 

    return length == 0; 
}

int String::operator==(const String & right) const 

    return strcmp(sPtr, right.sPtr)==0; 
}

int String::operator!=(const String & right) const 

    return strcmp(sPtr, right.sPtr)!=0; 
}

int String::operator<(const String & right) const 

    return strcmp(sPtr, right.sPtr)<0; 
}

int String::operator>(const String & right) const 

    return strcmp(sPtr, right.sPtr)>0; 
}

 

int String::operator<=(const String & right) const


    return strcmp(sPtr, right.sPtr)<=0; 
}

int String::operator>=(const String & right) const 

    return strcmp(sPtr, right.sPtr)>=0; 
}

//返回对String中某个字符的引用 
char & String::operator [](int subscript) 

    //首先测试下标是否越界 
    assert(subscript>=0 && subscript<length); 
    return sPtr[subscript]; 
}

String & String::operator()(int index, int sublength) 

    //首先测试下标是否越界 
    assert(index>=0 && index<length && sublength >= 0);

    String * subPtr = new String; 
    assert(subPtr!=0);

    //计算子字符串长度 
    int size = 0; 
    if(sublength == 0 || (index+sublength>length)) 
    { 
        size = length - index + 1; 
    } 
    else 
    { 
        size = sublength + 1; 
    } 
    //分配子字符串内存 
    delete subPtr->sPtr; 
    subPtr->length = size; 
    subPtr->sPtr = new char[size]; 
    assert(subPtr->sPtr!=0);

    int i = index, j=0; 
    //把子字符串拷贝到新的对象中 
    for( ; i<index+size-1; i++, j++) 
    { 
        subPtr->sPtr[j] = sPtr[i]; 
    }

    subPtr->sPtr[j] = '/0'; 
    return *subPtr; 
}

int String::GetLength() const 

    return length; 
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
`OutputDebugStringA`函数是用于向调试器输出I字符串的,而不是UTF-8字符串。如果你想要输出UTF-8的字符串,你需要将UTF-8字符串换为ANSI字符串,然后再调用`OutputDebugStringA`函数。 以下是一个示例代码,演示如何将UTF-8字符串转换为ANSI字符串并输出到调试器: ```cpp #include <windows.h> #include <iostream> #include <string> void OutputDebugStringUTF8(const std::string& utf8String) { int length = MultiByteToWideChar(CP_UTF8, 0, utf8String.c_str(), -1, NULL, 0); if (length == 0) { std::cout << "Failed to convert UTF-8 string to wide string." << std::endl; return; } std::wstring wideString(length, L'\0'); MultiByteToWideChar(CP_UTF8, 0, utf8String.c_str(), -1, &wideString[0], length); int ansiLength = WideCharToMultiByte(CP_ACP, 0, wideString.c_str(), -1, NULL, 0, NULL, NULL); if (ansiLength == 0) { std::cout << "Failed to convert wide string to ANSI string." << std::endl; return; } std::string ansiString(ansiLength, '\0'); WideCharToMultiByte(CP_ACP, 0, wideString.c_str(), -1, &ansiString[0], ansiLength, NULL, NULL); OutputDebugStringA(ansiString.c_str()); } int main() { std::string utf8String = u8"你好,世界!"; OutputDebugStringUTF8(utf8String); return 0; } ``` 在这个示例代码中,我们定义了一个名为`OutputDebugStringUTF8`的函数,用于输出UTF-8字符串到调试器。 首先,我们使用`MultiByteToWideChar`函数将UTF-8字符串转换为宽字符串(UTF-16)。我们首先调用一次`MultiByteToWideChar`函数来获取转换后的宽字符串的长度,然后创建一个足够容纳宽字符串的`std::wstring`对象,并再次调用`MultiByteToWideChar`函数进行实际的转换。 然后,我们使用`WideCharToMultiByte`函数将宽字符串转换为ANSI字符串。我们首先调用一次`WideCharToMultiByte`函数来获取转换后的ANSI字符串的长度,然后创建一个足够容纳ANSI字符串的`std::string`对象,并再次调用`WideCharToMultiByte`函数进行实际的转换。 最后,我们调用`OutputDebugStringA`函数来输出ANSI字符串到调试器。 在`main`函数中,我们定义了一个UTF-8字符串`utf8String`,然后调用`OutputDebugStringUTF8`函数将其输出到调试器。 希望这个示例代码可以帮助你将UTF-8字符串输出到调试器。如果有任何进一步的问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值