• 【C++面试】常考题复习


    // CPP_Test@2014.10.22.cpp : 定义控制台应用程序的入口点。
    //
    
    #include "stdafx.h"
    #include <assert.h>
    
    /************************************************************************/
    /* copyright (c) 2014 kernel_main
    /* c++试常考点
    /* 转载请注明出处:http://www.cnblogs.com/kernel0815/
    /************************************************************************/
    
    //strcpy 函数实现
    char* strcpy(char* strDst, const char* strSrc)
    {
        assert((NULL!=strDst) && (NULL!=strSrc));//断言字符串地址非0
        char* address = strDst;
        while((*strDst++ = *strSrc++) != '');
        return address;
    }
    
    //strlen 函数实现
    int strlen(const char* str)
    {
        assert(NULL != str);//断言字符串地址非0
        int len = 0;
        while (*str++ != '')
        {
            len++;
        }
    
        return len;
    }
    
    //String 实现
    class String
    {
    public:
        String(const char* str =NULL); //构造函数
        String(String & str);        //拷贝构造函数
        ~String(void);               //析构函数
    public:
        void print();
        String& operator=(const String &str);//赋值函数
    
    private:
        char* m_data;// 用于保存字符串
    };
    
    String::String(const char* str)
    {
        if (NULL == str)
        {
            m_data = new char[1];//得分点:对空字符串自动申请存放结束标志''的空
            assert(NULL != m_data);//加分点:对m_data加NULL 判断
            *m_data = '';      
        }
        else
        {
            int len = strlen(str);
            m_data = new char[len+1];
            assert(NULL != m_data);// 若能加 NULL 判断则更好
            strcpy(m_data, str);
        }
    }
    
    String::String(String & str)
    {
        int len = strlen(str.m_data);
        m_data = new char[len+1];//加分点:对m_data加NULL判断
        assert(NULL != m_data);
        strcpy(m_data,str.m_data);
    }
    
    String::~String()
    {
        if (m_data)
        {
            delete[] m_data;
            m_data = NULL;
        }
    }
    
    String& String::operator=(const String& str)
    {
        if (this == &str)//得分点:检查自赋值
        {
            return *this;
        }
    
        //得分点:释放原有的内存资源
        if (m_data)
        {
            delete[] m_data;
        }
    
        int len = strlen(str.m_data);
        m_data = new char[len+1]; //加分点:对m_data加NULL判断
        strcpy(m_data, str.m_data);
    
        return *this;//得分点:返回本对象的引用
    }
    
    void String::print()
    {
        printf("pint: %s @ 0x%08x
    ", m_data);
    }
    
    //检测CPU是Little_endian还是Big_endian
    //在实际内存中:
    //0x12345678 四个字节(相当于32bit CPU下的一个ulong、int)的内存存放形式如下:
    //Big_endian: 12 34 56 78    (将高序字节存储在起始地址, 低字节放高地址中, 高字节放低地址中)
    //little_endian: 78 56 34 12 (将低序字节存储在起始地址, 低字节放低地址中, 高字节放高地址中)
    int checkCPU()
    {
        union u
        {
            int a;
            char b;
        } c;
    
        //00 00 00 00
        c.a = 1;
    
    //     例子:如果我们将0x1234abcd写入到以0x0000开始的内存中,则结果为
    //         big-endian little-endian
    //         0x0000 0x12 0xcd
    //         0x0001 0x34 0xab
    //         0x0002 0xab 0x34
    //         0x0003 0xcd 0x12
    //  同样这个例子中:将1(即0x00000001)写入:
    //         big-endian little-endian
    //         0x0000 0x00 0x01
    //         0x0001 0x00 0x00
    //         0x0002 0x00 0x00
    //         0x0003 0x01 0x00 
    
        return (1 == c.b);  //--如果是big_endian,
    }
    
    int _tmain(int argc, _TCHAR* argv[])
    {
    
        String a("Hello World.");
        String b(a);
        String c = b;
        char* p = NULL;
    
        String d(p);
        d.print();
    
        a.print();
        b.print();
        c.print();
    
    
        printf("this computer is %s CPU
    ", checkCPU()?"little_endian":"big_endian");
    
        return 0;
    }
  • 相关阅读:
    multi-task learning
    代码杂谈-python函数
    代码杂谈-or符号
    安装maven
    zsh
    mint linux的几个问题
    [软件] Omnigraffle
    无梯度优化算法
    根据pdf文件获取标题等信息
    计算广告-GD广告
  • 原文地址:https://www.cnblogs.com/kernel0815/p/4044725.html
Copyright © 2020-2023  润新知