string类的实现


#include<iostream>  

#include<iomanip>  

using namespace std;  

  

class String{  

    friend ostream& operator<< (ostream&,String&);//重载<<运算符  

    friend istream& operator>> (istream&,String&);//重载>>运算符  

public:  

    String(const char* str=NULL);                //赋值构造兼默认构造函数(char)  

    String(const String &other);                 //赋值构造函数(String)  

    String& operator=(const String& other);       //operator=  

    String operator+(const String &other)const;  //operator+  

    bool operator==(const String&);              //operator==  

    char& operator[](unsigned int);              //operator[]  

    size_t size(){return strlen(m_data);};  

    ~String(void) {delete[] m_data;}  

private:  

    char *m_data; // 用于保存字符串  

};  

  

inline String::String(const char* str)     

{  

    if(!str)m_data=0;      //声明为inline函数,则该函数在程序中被执行时是语句直接替换,而不是被调用  

    else {  

        m_data=new char[strlen(str)+1];  

        strcpy(m_data,str);  

    }  

}  

  

inline String::String(const String &other)  

{  

    if(!other.m_data)m_data=0;//在类的成员函数内可以访问同种对象的私有成员(同种类则是友元关系)  

    else   

    {  

        m_data=new char[strlen(other.m_data)+1];  

        strcpy(m_data,other.m_data);  

    }  

}  

  

inline String& String::operator=(const String& other)  

{  

    if (this!=&other)  

    {  

        delete[] m_data;  

        if(!other.m_data) m_data=0;  

        else  

        {  

            m_data = new char[strlen(other.m_data)+1];  

            strcpy(m_data,other.m_data);  

        }  

    }  

    return *this;  

}  

inline String String::operator+(const String &other)const  

{  

    String newString;  

    if(!other.m_data)  

        newString = *this;  

    else if(!m_data)  

        newString = other;  

    else  

    {  

        newString.m_data = new char[strlen(m_data)+strlen(other.m_data)+1];  

        strcpy(newString.m_data,m_data);  

        strcat(newString.m_data,other.m_data);  

    }  

    return newString;  

}  

  

inline bool String::operator==(const String &s)      

{  

    if ( strlen(s.m_data) != strlen(m_data) )  

        return false;  

    return strcmp(m_data,s.m_data)?false:true;  

}  

  

inline char& String::operator[](unsigned int e)  

{  

    if (e>=0&&e<=strlen(m_data))  

        return m_data[e];  

}  

  

ostream& operator<<(ostream& os,String& str)  

{  

    os << str.m_data;  

    return os;  

}  

  

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

{  

   char temp[ 255 ]; //用于存储输入流  

   input>>setw(255)>>temp;  

   s = temp; //使用赋值运算符  

   return input; //使用return可以支持连续使用>>运算符  

}  

  

int main()  

{  

    String str1="Aha!";  

    String str2="My friend";  

    String str3 = str1+str2;  

    cout<<str3<<"/n"<<str3.size()<<endl;  

    return 0;  

}  


内容概要:文章基于4A架构(业务架构、应用架构、数据架构、技术架构),对SAP的成本中心和利润中心进行了详细对比分析。业务架构上,成本中心是成本控制的责任单元,负责成本归集与控制,而利润中心是利润创造的独立实体,负责收入、成本和利润的核算。应用架构方面,两者都依托于SAP的CO模块,但功能有所区分,如成本中心侧重于成本要素归集和预算管理,利润中心则关注内部交易核算和获利能力分析。数据架构中,成本中心与利润中心存在多对一的关系,交易数据通过成本归集、分摊和利润计算流程联动。技术架构依赖SAP S/4HANA的内存计算和ABAP技术,支持实时核算与跨系统集成。总结来看,成本中心和利润中心在4A架构下相互关联,共同为企业提供精细化管理和决策支持。 适合人群:从事企业财务管理、成本控制或利润核算的专业人员,以及对SAP系统有一定了解的企业信息化管理人员。 使用场景及目标:①帮助企业理解成本中心和利润中心在4A架构下的运作机制;②指导企业在实施SAP系统时合理配置成本中心和利润中心,优化业务流程;③提升企业对成本和利润的精细化管理水平,支持业务决策。 其他说明:文章不仅阐述了理论概念,还提供了具体的应用场景和技术实现方式,有助于读者全面理解并应用于实际工作中。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值