首页 > 其他分享 >实验一 类与对象(1)

实验一 类与对象(1)

时间:2022-10-03 17:44:10浏览次数:47  
标签:const width 对象 double int length 实验 Rectangle

实验二:

代码如下:

 

#include<iostream>
using namespace std;

class Point{
    public:
        Point(int x0 = 0, int y0 = 0);
        Point(const Point &p);
        ~Point()=default;
        
        int get_x() const {return x;}
        int get_y() const { return y; }
        void show() const;
        
    private:
        int x,y;
};

Point::Point(int x0, int y0): x{x0}, y{y0} {
    cout << "constructor called." << endl;
}
Point::Point(const Point& p): x{p.x}, y{p.y} {
    cout << "copy constructor called." << endl;
}
void Point::show() const {
    cout << "(" << x << ", " << y << ")" << endl;
}

int main()
{
    Point p1(1217,1118);
    p1.show();
    
    Point p2 = p1;
    p2.show();
    
    Point p3{p2};
    p3.show();
    cout << p3.get_x() << endl;
}

 

运行结果:

 

 

 

 

实验三:

代码如下:

 

#include<iostream>
#include<iomanip>
using namespace std;

class Clock{
    public:
        Clock(int h = 0,int m = 0,int s = 0);
        Clock(const Clock &t);
        ~Clock()=default;
        
        void set_time(int h,int m = 0,int s = 0);
        void show_time() const;
    private:
        int hour,minute,second;
};
Clock::Clock(int h, int m, int s): hour{h}, minute{m}, second{s} {
    cout << "constructor called" << endl;
}
Clock::Clock(const Clock& t): hour{t.hour}, minute{t.minute},second{t.second} {
    cout << "copy constructor called" << endl;
}
void Clock::set_time(int h, int m, int s) {
    hour = h; 
    minute = m; 
    second = s;
}
void Clock::show_time() const {
    cout << setfill('0') << setw(2) << hour << ":" << setw(2) << minute << ":"
    << setw(2) << second << endl;
}
Clock reset() {
    return Clock(0, 0, 0);
}

int main()
{
    Clock c1(2,12,17);
    c1.show_time();
    
    c1 = reset();
    c1.show_time();
    
    Clock c2(c1);
    c2.set_time(2,11,18);
    c2.show_time();
}

 

运行结果:

 

 

 

 

实验四:

代码如下:

 

#include<iostream>
using namespace std;
class X{
    public:
        X();
        ~X();
        X(int m);
        X(const X& obj);
        X(X&& obj) noexcept;
        void show() const;
    private:
        int data;
}; 
X::X(): data{42} {
    std::cout << "default constructor called.\n";
}
X::~X() {
    std::cout << "destructor called.\n";
}
X::X(int m): data{m} {
    std::cout << "constructor called.\n";
}
X::X(const X& obj): data{obj.data} {
    std::cout << "copy constructor called.\n";
}
X::X(X&& obj) noexcept: data{obj.data} {
    std::cout << "move constructor called.\n";
}
void X::show() const {
    std::cout << data << std::endl;
}
int main()
{
    X x1;
    x1.show();
    
    X x2{2049};
    x2.show();
    
    X x3{x1};
    x3.show();
    
    X x4{ std::move(x2) };
    x4.show();
}

 

运行结果:

分析:

第34行:  X x1;            默认构造函数被调用。

第37行:  X x2{2049};         构造函数被调用。

第40行:  X x3{x1};          复制构造函数被调用。

第43行:  X x4{ std::move(x2) };    移动构造函数被调用。

第44行,函数运行结束,对象即将消失时,析构函数被调用,析构函数按对象被定义的顺序,从后往前清除。

 

 

实验五:

代码如下:

 

#include<iostream>
#include <iomanip>
using namespace std;

class Rectangle{
    public:
        Rectangle();
        Rectangle(double l,double w);
        Rectangle(const Rectangle &rect);
        ~Rectangle()=default;
        double get_len() {return length;}
        double get_wide() {return width;}
        double area() {return length*width;}
        double circumference() {return 2*(length+width);}
        double resize(double times) {length=times*length,width=times*width;}
        double resize(double l_times,double w_times) { length*=l_times,width*=w_times;}
    private:
        double length,width;
}; 
Rectangle::Rectangle(): length{2.0},width{1.0}{}

Rectangle::Rectangle(double l,double w): length{l},width{w}{}

Rectangle::Rectangle(const Rectangle& rect): length{rect.length},width{rect.width}{}

void output(const Rectangle &rect) {
    Rectangle a=rect;
    cout << "矩形信息: \n";
    cout << fixed << setprecision(2);
    cout << "长:     " << a.get_len() <<endl
    << "宽:     " << a.get_wide() <<endl
    <<"面积:   " << a.area() <<endl
    <<"周长:   " << a.circumference() << endl <<endl;

}
int main()
{
    Rectangle rect1;
    output(rect1);
    
    Rectangle rect2(10, 5);
    output(rect2);
    
    Rectangle rect3(rect1);
    rect3.resize(2);
    output(rect3);
    
    rect3.resize(5, 2);
    output(rect3);
}

 

运行结果:

 

 

 

 

标签:const,width,对象,double,int,length,实验,Rectangle
From: https://www.cnblogs.com/whwssr/p/16750859.html

相关文章

  • 实验3:OpenFlow协议分析实践
    1)hello控制器6633端口(最高支持OpenFlow1.0)-->交换机50822端口交换机50822端口(最高支持OpenFlow1.5)-->控制器6633端口2)FeatureRequest控制器6633端口(需要你的特征......
  • 实验4:开源控制器实践——OpenDaylight
    实验4:开源控制器实践——OpenDaylight一、实验目的能够独立完成OpenDaylight控制器的安装配置;能够使用Postman工具调用OpenDaylightAPI接口下发流表。二、实验环境Ub......
  • 实验4:开源控制器实践——OpenDaylight
    实验4:开源控制器实践——OpenDaylight一、实验目的1.能够独立完成OpenDaylight控制器的安装配置;2.能够使用Postman工具调用OpenDaylightAPI接口下发流表。二、实验环......
  • 4、STL-函数对象
    4、STL-函数对象4.1函数对象4.1.1函数对象概念概念:重载函数调用操作符的类,其对象常称为函数对象函数对象使用重载()的时候,行为类似函数调用,也叫仿函数本质:函数对......
  • 基于SqlSugar的开发框架循序渐进介绍(14)-- 基于Vue3+TypeScript的全局对象的注入和使用
    刚完成一些前端项目的开发,腾出精力来总结一些前端开发的技术点,以及继续完善基于SqlSugar的开发框架循序渐进介绍的系列文章,本篇随笔主要介绍一下基于Vue3+TypeScript的全局......
  • 实验4:开源控制器实践——OpenDaylight
    一、实验目的能够独立完成OpenDaylight控制器的安装配置;能够使用Postman工具调用OpenDaylightAPI接口下发流表。二、实验环境Ubuntu20.04Desktopamd64三、实验......
  • JAVA对象的内存解析
    堆(Heap):此内存区域用来存放对象实例栈(Stack): 存储局部变量,局部变量存储有数据类型(boolean,byte,int,short,int,float,long,double)、对象引用(reference类型,是对象在堆内......
  • 007.注入集合对象
           ......
  • 实验3:OpenFlow协议分析实践
    实验3:OpenFlow协议分析实践一、实验目的能够运用wireshark对OpenFlow协议数据交互过程进行抓包;能够借助包解析工具,分析与解释OpenFlow协议的数据包交互过程与机......
  • 实验4:开源控制器实践——OpenDaylight
    (一)基本要求Mininet拓扑生成并连接控制器Mininet中ping测试(二)进阶要求查找资料,整理和记录ODL控制器主要的RESTAPI文档,包括但不限于ODL提供的文档链接,获取拓扑......