C++day2(笔记整理)

一、Xmind整理:

二、上课笔记整理:

1.左值引用

#include <iostream>
using namespace std;

int main()
{
    int a = 100;
    int &ra = a;    //定义了变量a的引用ra
    cout << &a << endl;
    cout << "&ra=" << &ra << endl;
    int &rb = a;
    int &rra = ra;
    cout <<  &rra << endl;
    cout <<  &rb << endl;
    return 0;
}

2.引用作为函数的形参

#include <iostream>
using namespace std;

void swap(int &n1,int &n2)
//引用作为函数的形参,传递实参本身到函数中
{
    int temp;
    temp = n1;
    n1 = n2;
    n2 = temp;
}
int main()
{
    int a=90,b=80;
    cout << "a=" << a << endl;
    cout << "b=" << b << endl;
//    int &p = a;
//    int &q = b;
    swap(a,b);  //调用结束后,实参会发生交换
    cout << "调用后" << endl;
    cout << "a=" << a << endl;
    cout << "b=" << b << endl;
    return 0;
}

3.尝试实现,冒泡排序,要求:引用作为函数的形参。

#include <iostream>

using namespace std;
void fun(int (&s)[5])
{
    int i=1,j=0,temp;
    for(i=1;i<5;i++)
    {
        for (j=0;j<5-i;j++)
        {
            if(s[j]>s[j+1])
            {
                temp = s[j];
                s[j] = s[j+1];
                s[j+1] = temp;
            }
        }
    }
}
int main()
{
    int arr[5]={2,9,7,1,6};
    int a;
    int &ra = a;
    int (&pa)[5] = arr;
    cout << sizeof(arr) << endl;
    cout << sizeof(pa) << endl;
    return 0;
}

4.引用作为函数的返回值

#include <iostream>
using namespace std;

//函数的返回值和形参皆为引用
int &fun(int &a,int &b)
{
    a = a+b;
    return a;
}
int fun1(int a,int b)
{
    a = a+b;
    return a;
}
int main()
{
    int nu1 = 100,nu2=7;
    fun(nu1,nu2)=90;   //<===>nu1=90
    cout << "nu1=" << nu1 << endl;
    cout << "nu2=" << nu2 << endl;
    //cout << ret << endl;
    return 0;
}

5.常引用

#include <iostream>
using namespace std;

int main()
{
    int num1 = 90;
    const int &ra = num1;  //定义了一个常引用ra,目标是非常变量num1
    num1 = 8;
    //ra = 70;
    const int num2 = 0;
    const int &rb = num2;  //定义了一个常引用rb,目标是常变量num2
    //既不能通过引用修改num2,也不能通过目标num2修改自身的值    
    return 0;
}

6.结构体中的引用成员

#include <iostream>
using namespace std;

struct Stu
{
    string name;
    int &age;
};

int main()
{
    int x = 18;

    //定义一个结构体变量s1,由于Stu中有引用成员,所以结构体变量必须初始化
    struct Stu s1={"zhangsan",x};

    cout << s1.name << endl;
    cout << s1.age << endl;
    return 0;
}

7.引用和指针的区别(笔试题)

1.引用必须初始化,指针可以不初始化(野指针),指针可以指向NULL,引用不能为空,引用一定有明确的目标

2.指针可以修改指向,引用一旦指定目标,不能再修改

3.指针在使用前,需要做合理性检查,但是引用不需要

4.指针会另外开辟空间,但是引用不开辟空间,和目标使用同一片空间

5.指针的大小是8byte/4Byte,引用的大小和目标的大小一致

6.有多级指针,没有多级引用

7.有指针数组,但是没有引用数组

8.使用new申请单个内存空间 

数据类型 *指针名 =  new  数据类型;
new的结果,就是一个对应数据类型的指针,不需要强转

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

int main()
{
    int a = 100;
    int *p = (int *)malloc(sizeof(int));   //使用malloc申请了堆区的4Byte的空间
    cout << *p << endl;   //随机值


//------------------使用new申请空间-----------------
    int *p1 = new int;    //使用new申请了堆区的一个int大小的空间
    cout << p1 << endl;
    *p1 = 90;
    cout << *p1 << endl;


    int *p2 = new int(45);  //使用new在堆区申请了一个int类型的控制,并赋初始值为45
    cout << *p2 << endl;
    return 0;
}

9.使用new申请连续的内存空间

1、只申请空间,不进行初始化操作
数据类型 *指针名 = new 数据类型[个数]
2、申请空间,并初始化
数据类型 *指针名 = new 数据类型[个数]{初始值}


#include <iostream>
using namespace std;

int main()
{
    //使用new申请连续的空间
    int *p = new int[5];      //在堆区申请了5个int的空间

    cout << p << endl;
    cout << p+1 << endl;
    cout << p+2 << endl;
    cout << p+3 << endl;
    cout << p+4 << endl;
    for (int i=0;i<5;i++)
    {
        cout << p[i] << endl;    //随机值
    }

    //申请连续的空间并初始化
    int *p2 = new int[5]{1,2,3,4,5};
    for (int i=0;i<5;i++)
    {
        cout << p2[i] << endl;   //1,2,3,4,5
    }
    return 0;
}

10.delete

1、delete释放单个空间
delete 指针名;    ---->delete p
2、delete释放连续空间
delete []指针名;    ---->delete []p
[]内不能写任何内容,只做引导delete释放多个空间使用

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

int main()
{
//------------------使用new申请空间-----------------
    int *p1 = new int;    //使用new申请了堆区的一个int大小的空间
    cout << p1 << endl;
    *p1 = 90;
    cout << *p1 << endl;
    delete p1;
    p1 = nullptr;  //和NULL是一样的效果

    int *p2 = new int(45);  //使用new在堆区申请了一个int类型的控制,并赋初始值为45
    cout << *p2 << endl;
    int *p3 = new int[5]{1,2,3,4,5};
    delete []p3;    //释放连续空间时,需要加[]
    p3 = nullptr;
    return 0;
}

11.C++提供new/delete为什么不适用malloc/free

new和delete在申请和释放类对象空间是,new会自动调用构造函数,delete会自动调用析构函数,但是malloc/free不会。

12.new/delete和malloc/free的区别(笔试题)

1.new/delete是C++中的关键字,malloc和free是C中的库函数

2.new/delete会自动调用构造和析构函数

3.new申请空间时以数据类型为单位,malloc以字节大小为单位

4.new在申请空间的同时可以初始化,malloc不行

5.free在释放空间时,不需要考虑连续空间的问题,但是delete在释放连续空间时,需要手动加[],delete []指针名

13.函数重载的代码 

#include <iostream>
using namespace std;
//实现函数重载

//整型变量的加法函数
int add(int num1,int num2)   //addii
{
    return num1+num2;
}

//字符型变量的加法函数
char add(char num1,char num2)   //addcc
{
    return num1+num2;
}

//浮点型变量的加法函数
float add(float num1,float num2)   //addff
{
    return num1+num2;
}
int main()
{
    int a=55,b=9;
    char num1 = 90,num2 = 7;
    float n1 = 9.0,n2 = 3.14;

    cout << add(a,b) << endl;
    cout << add(n1,n2) << endl;
    cout << add(num1,num2) << endl;
    return 0;
}

14.函数参数的默认值

#include <iostream>
using namespace std;

int add(int num1,int num2,int num3=9);
int main()
{
    int ret = add(3,5);
    cout << ret << endl;
    return 0;
}

int add(int num1,int num2,int num3)
{
    return num1+num2+num3;
}

15.当函数重载和默认参数同时出现

#include <iostream>

using namespace std;
int add(int num1,int num2,int num3=9);
//int add(int num1,int num2)
//{
//    return num1+num2;
//}
int main()
{
    int ret = add(3,5);
    cout << ret << endl;
    return 0;
}

int add(int num1,int num2,int num3)
{
    return num1+num2+num3;
}

16.哑元

#include <iostream>
using namespace std;

int add(int num1,int num2,int);
int main()
{
    int ret = add(3,5,1);
    add(1,2,3);
    add(4,5,6);
    add(4,5,6);
    add(4,5,6);
    add(4,5,6);
    cout << ret << endl;
    return 0;
}

//add函数的,第三个参数是一个哑元
int add(int num1,int num2,int)
{
    return num1+num2;
}

17.内联函数(inline)

格式:
inline 函数头; 

#include <iostream>

using namespace std;
int add(int num1,int num2,int);
int main()
{
    int ret = add(3,5,1);
    add(1,2,3);
    add(4,5,6);
    add(4,5,6);
    add(4,5,6);
    add(4,5,6);
    cout << ret << endl;
    return 0;
}

//add函数的,第三个参数是一个哑元
inline int add(int num1,int num2,int)
{
    cout << num1 << endl;
    cout << num1 << endl;
    cout << num1 << endl;
    cout << num1 << endl;
    cout << num1 << endl;
    cout << num1 << endl;
    return num1+num2;
}

18.C++中的结构体

#include <iostream>

using namespace std;

struct Stu
{
    //public
    //private
   string name;

   void fun();     //在结构体内声明函数
   void set_age(int a)   //给结构体中的私有成员赋值,私有成员可以通过结构体内的公有函数访问
   {
       age = a;
   }
private:
   int age=18;
};

//结构体外定义函数
void Stu::fun()
{
    cout << name << endl;
    cout << age << endl;
}
int main()
{
    Stu s1;
    s1.name = "zhangsan";
    s1.set_age(1000);
    s1.fun();
    return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/85785.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

wx原生微信小程序入门常用总结

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、定义值和修改值1、定义值2、修改值&#xff08;1&#xff09;代码&#xff08;2&#xff09;代码说明&#xff08;3&#xff09;注意点 二、点击事件三、微…

机器人TF坐标系变换与一些可视化工具的应用

TF坐标在ROS中是一个非常重要的概念&#xff0c;因为机器人在做日常操作任务的时候&#xff0c;对于其所在位置和朝向是需要时刻知道的&#xff0c;而机器人是由很多节点组成的协同任务&#xff0c;对于每个部件&#xff0c;我们需要知道它的位姿(位置和朝向)&#xff0c;这使得…

React+Typescript使用接口泛型处理props

好 刚讲完组件 那么 这次 我们来看一下 数据传递的 props 还是上文的案例 例如 我们想将 title 传给Hello组件 之前我们可以直接这样 以一个标签属性的形式传过去 而我们在子组件中 这样去使用 但现在 我们从编辑器中都可以看出 这种写法已经不行了 然后 我们将 hello 组件…

Windows 11 + Ubuntu20.04 双系统 坑里爬起来

ThinkPad x390 安装双系统&#xff0c;原有的磁盘太小&#xff0c;扩充了磁盘重新装系统&#xff0c;出现的问题&#xff0c;加以记录。 1. windows和ubuntu谁先安装&#xff0c;两个都可以&#xff0c;一般建议先安装windows&#xff0c;后安装ubuntu 2. 安装windows后&…

c++--动态规划回文串问题

1.回文子串 力扣&#xff08;LeetCode&#xff09;官网 - 全球极客挚爱的技术成长平台 给定一个字符串 s &#xff0c;请计算这个字符串中有多少个回文子字符串。 具有不同开始位置或结束位置的子串&#xff0c;即使是由相同的字符组成&#xff0c;也会被视作不同的子串。 示…

无涯教程-Perl - time函数

描述 此函数返回自纪元以来的秒数(对于大多数系统,是1970年1月1日UTC,00:00:00&#xff1b;对于Mac OS,是1904年1月1日,00:00:00)。适用于gmtime和本地时间。 语法 以下是此函数的简单语法- time返回值 此函数返回自纪元后数秒的整数。 例 以下是显示其基本用法的示例代…

如何实现24/7客户服务自动化?建设智能客服知识库

客户自助服务是指用户通过企业或者第三方建立的网络平台或者终端&#xff0c;实现相关的自定义处理。实现客户服务自动化&#xff0c;对提高客户满意度、维持客户关系至关重要。客户服务自动化可以帮助企业以更快的速度和更高的效率来满足客户的售后服务要求&#xff0c;以进一…

ssm助学贷款系统源码和论文

ssm助学贷款系统源码和论文050 开发工具&#xff1a;idea 数据库mysql5.7 数据库链接工具&#xff1a;navcat,小海豚等 技术&#xff1a;ssm 摘 要 现代经济快节奏发展以及不断完善升级的信息化技术&#xff0c;让传统数据信息的管理升级为软件存储&#xff0c;归纳&am…

使用vscode编写插件-php语言

https://blog.csdn.net/qq_45701130/article/details/125206645 一、环境搭建 1、安装 Visual Studio Code 2、安装 Node.js 3、安装 Git 4、安装生产插件代码的工具&#xff1a;npm install -g yo generator-code 二、创建工程 yo code 选择项解释&#xff1a; 选择编写扩…

JVM性能调优

java 如何跨平台&#xff0c;如何一次编译到处执行 是由于java在不同的jvm上编译&#xff0c;jvm在软件层面屏蔽不同操作系统在底层硬件与指令上的区别。 jvm 包括 new 的对象都是放在堆中 栈&#xff0c;给线程单独使用&#xff08;线程私有&#xff09;&#xff0c;存储一个…

Java-进程调度算法

文章目录 为什么要设置进程调度算法&#xff1f;分类1. 先进先出&#xff08;FIFO&#xff09;算法优缺点FIFO代码示例 2. 短作业优先&#xff08;SJF&#xff09;算法优缺点示例代码 3. 优先级算法&#xff08;Priority scheduling&#xff09;优缺点示例代码 4. 时间片轮转算…

Midjourney API 国内申请及对接方式

在人工智能绘图领域&#xff0c;想必大家听说过 Midjourney 的大名吧&#xff01; Midjourney 以其出色的绘图能力在业界独树一帜。无需过多复杂的操作&#xff0c;只要简单输入绘图指令&#xff0c;这个神奇的工具就能在瞬间为我们呈现出对应的图像。无论是任何物体还是任何风…

Docker容器与虚拟化技术:Docker consul 实现服务注册与发现

目录 一、理论 1.Docker consul 二、实验 1.consul部署 2. consul-template部署 三、总结 一、理论 1.Docker consul &#xff08;1&#xff09;服务注册与发现 服务注册与发现是微服务架构中不可或缺的重要组件。起初服务都是单节点的&#xff0c;不保障高可用性&…

解决Linux虚拟机IP无法显示的问题

目录 问题&#xff1a; 两种解决方案&#xff0c;供大家选择使用哦。 第一种解决办法&#xff1a; 第二种解决办法&#xff1a; 1、查看ens33网卡的配置 2、修改文件 扩展&#xff1a; 问题&#xff1a; Linux命令 ip a 查看ip时&#xff0c;无法显示IP的解决办法。 两…

lnmp(docker)

1. 建立工作目录 [rootdocker ~]# mkdir /opt/nginx [rootdocker ~]# cd /opt/nginx [rootdocker nginx]# rz -E rz waiting to receive. #上传 nginx 安装包 nginx-1.12.0.tar.gz[rootdocker nginx]# rz -E rz waiting to receive. #上传 wordpress 服务包 wordpress-4.9.4-z…

vscode远程调试

安装ssh 在vscode扩展插件搜索remote-ssh安装 如果连接失败&#xff0c;出现 Resolver error: Error: XHR failedscode 报错&#xff0c;可以看这篇帖子vscode ssh: Resolver error: Error: XHR failedscode错误_阿伟跑呀的博客-CSDN博客 添加好后点击左上角的加号&#xff0…

Python功能制作之简单的音乐播放器

需要导入的库&#xff1a; pip install PyQt5 源码&#xff1a; import os from PyQt5.QtCore import Qt, QUrl from PyQt5.QtGui import QIcon, QPixmap from PyQt5.QtMultimedia import QMediaPlayer, QMediaContent from PyQt5.QtWidgets import QApplication, QMainWind…

剪枝基础与实战(1): 概述

本文介绍基于L1正则化的剪枝原理,并以VGG网络进行实战说明。将从零详细介绍模型训练、稀疏化、剪枝、finetune的全过程,提供详细的源码及说明,有助于对剪枝的熟练掌握,后续也会对yolov8进行剪枝的介绍。 论文: Learning Efficient Convolutional Networks through Network …

激活函数总结(十七):激活函数补充(PELU、Phish)

激活函数总结&#xff08;十七&#xff09;&#xff1a;激活函数补充 1 引言2 激活函数2.1 Parametric Exponential Linear Unit&#xff08;PELU&#xff09;激活函数2.2 Phish激活函数 3. 总结 1 引言 在前面的文章中已经介绍了介绍了一系列激活函数 (Sigmoid、Tanh、ReLU、…

SAP S/4HANA 2022:MRP Live 和 Classic MRP新的增强BADI

翻译一篇&#xff0c;原文在SAP BLOG中如下&#xff1a; 目录 前言通过 BADIs 操作 MRP 元素新的 BadI PPH_SUPPLY_DEMAND_LISTBADI PPH_SUPPLY_DEMAND_LIST 的示例实现结论 前言 SAP S/4HANA 引入了新的 BADI PPH_SUPPLY_DEMAND_LIST&#xff0c;它允许我们在MRP Live 和 C…