结构体(参数、嵌套)、结构体指针、结构体中const的使用场景

2023-05-16

结构体:属于用户自定义的数据类型,允许用户存储不同的数据类型;

结构体定义和使用

通过结构体创建变量的方式有三种:

  1. struct 结构体名 变量名
  2. struct 结构体名 变量名 = { 成员1,成员2...}
  3. 定义结构体时顺便创建变量

#include <iostream>

#include <string>

using namespace std;

// Step 1、创建学生数据类型---结构体是一些类型集合组成的一个类型

// 定义结构体变量

struct student

{

// 成员列表(属性列表)

string name;

int age;

int score;

}s3; // 第三种 定义结构体时顺便创建变量

int main()

{

// Step 2、通过学生类型创建具体学生(有三种方式创建它)

// 第一种 struct student s1(即struct 结构体名 变量名)

struct student s1;

// 给s1的属性赋值

s1.name = "张三";

s1.age = 17;

s1.score = 100;

cout << " Name: " << s1.name<<" Age: "<< s1.age<<" Score: "<<s1.score<< endl; // 通过.来访问结构体的元素

// 第二种 struct student s2 = { ... }

struct student s2

{

"李四", 18, 99

};

cout << " Name: " << s2.name << " Age: " << s2.age << " Score: " << s2.score << endl;

// 第三种 定义结构体时顺便创建变量(见结构体定义处)

s3.name = "阿三";

s3.age = 17;

s3.score = 100;

cout << " Name: " << s3.name << " Age: " << s3.age << " Score: " << s3.score << endl;

system("pause");

return 0;

}

 

【注意】:C++中,在定义完结构体后,创建具体的结构体变量时可以不加struct关键字。

结构体数组

作用:将自定义的结构体放入到数组中方便维护

struct 结构体名 数组名[元素个数] = { {...}. {...}, ...{...} }

【注意】在创建结构体变量之前一定要事先定义了相应的结构体

结构体指针(结构体xx类型的指针)

作用:通过指针来访问结构体中的成员(利用操作符->可以通过结构体指针访问结构体的属性

#include <iostream>

#include <string>

using namespace std;

struct student

{

// 成员列表(属性列表)

string name;

int age;

int score;

};  

int main()

{

// 1、创建结构体变量

struct student s1 = { "qianqian", 18, 90 };

// 2、通过指针指向结构体变量(注意指针类型要和结构体类型一致

student *p = &s1;

// 3、通过指针访问结构体变量中的数据

cout << "name = :" << p->name << endl; // 通过结构体指针访问结构体变量中的属性需要利用操作符 ->

system("pause");

return 0;

}

结构体嵌套结构体

作用:结构体中的成员可以是另一个结构体

举例:每个老师辅导一个学员,一个老师的结构体中就需要嵌套有一个学生的结构体

#include <iostream>
#include <string>

using namespace std;

struct student
{
	// 成员列表(属性列表)
	string name;
	int age;
	int score;
};  

struct teacher
{
	int id;
	string name;
	int age;
	struct student xiaowang;	// 注意:学生的结构体需要写在老师的结构体之前
};

结构体作为函数参数

作用:将结构体作为参数向函数中传递

传递方式有两种:1、值传递(不会改变原来的结构体) 2、地址传递(会改变原来的结构体)

#include <iostream>
#include <string>

using namespace std;

void printStudent(struct student s);
void printStudent_2(struct student *s);

struct student
{
	// 成员列表(属性列表)
	string name;
	int age;
	int score;
};  


int main()
{
	// 结构体做函数参数
	// 将学生的结构体传入到一个参数中,打印学生身上的所有信息
	struct student s1;
	s1.age = 10;
	s1.name = "小明";
	s1.score = 100;

	printStudent(s1);
	cout << "值传递后main函数中的打印结果:" << s1.name << endl;

	printStudent_2(&s1);
	cout << "地址传递后main函数中的打印结果:" << s1.name << endl;

	system("pause");

	return 0;
}

// 1、值传递(不会改变原来的结构体)
void printStudent(struct student s) // 注意传进来的结构体类型必须是学生student类型
{
	s.age = 10;
	s.name = "小王";
	s.score = 100;
	
	cout << "printStudent函数中的打印结果:" << s.name << endl;
}

// 2、地址传递(会改变原来的结构体)
void printStudent_2(struct student *s) // 用指针来保存地址,注意指针类型
{
	s->age = 10; // 通过指针来访问结构体元素时用的是操作符 ->
	s->name = "小王";
	s->score = 100;

	cout << "printStudent_2函数中的打印结果:" << s->name << endl;
}

结构体中const的使用场景

作用:用const来防止误操作

 

#include <iostream>
#include <string>

using namespace std;

struct student
{
	// 成员列表(属性列表)
	string name;
	int age;
	int score;
};  
void printStudents(const student *s); // 注意这句要写在student结构体之后

int main()
{
	// 结构体中const的应用场景(const防止误操作)
	// 特别是该结构体很大时,如果用值传递的方式去操作,那么就会造成很大的额外开销
	// 所以一般是用 地址传递 加 const的方式来操作
	struct student s = { "xiaoming", 19, 99 };
	printStudents(&s);

	system("pause");
	return 0;
}

void printStudents(const student *s) // 将形参改为指针,可以减少内存空间,而且不会复制新的副本
{
	//s->age = 100; // 加入const之后,一旦有修改的操作就会报错
	cout << "age = :" <<s->age << endl;
}

// const student *s是一个常量指针,即其指向的是一个常量,也即传进来的结构体是一个常量

// const student *s是一个常量指针,即其指向的是一个常量,也即传进来的结构体是一个常量

常量指针见我上一篇文章。

https://blog.csdn.net/ainideren_/article/details/119089943

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

结构体(参数、嵌套)、结构体指针、结构体中const的使用场景 的相关文章

  • Openstack使用ubuntu镜像启动虚拟机实例

    一般情况下openstack环境搭建好了之后 xff0c 就是测试启动虚拟机 通常我们会使用一个最基本的镜像cirros 0 3 3 x86 64 disk img来作为镜 像 xff0c 使用glance命令行或者horizon的图形化界
  • docker使用Dockerfile构建镜像

    docker获取镜像 xff0c 除了docker pull docker load之外还可以通过自定义Dockerfile的方式通过命令docker build 来构建新镜像 通过这种方式可以很自由的定义想要安装的镜像 xff0c 想要安
  • django环境搭建

    django是python开发框架 xff0c 是一个丰富的web框架 第一步 xff1a 安装pip wget https bootstrap pypa io get pip py python get pip py 第二步 xff1a
  • docker配置国内仓库镜像registry-mirror

    Docker在默认安装之后 xff0c 当需要下载镜像时 xff0c 通过命令docker pull learn tutoral拉取示例镜像 xff0c 或者其他镜像时 xff0c 都是访问默认的docker hub上的镜像 xff0c 在
  • TypeError: object() takes no parameters

    python面向对象编程第一个坑 TypeError object takes no parameters 出现这个错误 xff0c 一般就是构造函数 init 书写的不对 xff0c 检查一下是否是少了一个下划线或者是少写了一个i字母 x
  • windows上Flask环境搭建

    Flask是python开发框架 用来快速构建web项目 下面介绍如何在windows上搭建flask开发环境并运行一个demo 第一步 创建项目并构建flask环境 mkdir flaskapp cd flaskapp virtualen
  • WebSocket 测试工具

    一 WebSocket 简介 WebSocket是一种在单个TCP连接上进行全双工通信的协议 WebSocket使得客户端和服务器之间的数据交换变得更加简单 xff0c 允许服务端主动向客户端推送数据 在WebSocket API中 xff
  • 利用pipework为docker容器设置固定IP

    今天介绍如何在redhat centos7系列机器上使用pipework为docker启动的容器指定一个固定ip 我们知道默认情况下 xff0c docker会使用bridge网络模式为每一个启动的容器动态分配一个IP xff0c 以172
  • 用docker玩坏ubuntu虚拟机容器

    当我们装上docker之后 xff0c 自然会pull一个或多个镜像玩玩 xff0c 这时候 xff0c docker hub仓库上有很多系列操作系统镜像 xff0c 每个系列又有很多不同功能的虚拟机镜像 xff0c 比如centos分6还
  • tornado入门实例

    tornado是python web开发的又一个轻量级框架 tornado框架需要安装 xff0c 为了方便 xff0c 我直接安装了Anaconda 2 4 1 里面直接就带了tornado 还有很多python库 numpy scipy
  • web.py框架入门

    web py是python web开发的一个轻量级框架 web py可以通过pip命令安装 xff0c pip install web py 编写官网示例代码 xff1a vi index py import web urls 61 34
  • graphviz快速上手

    graphviz最初是AT amp T实验室用来画流程图的工具 xff0c 使用dot语言 其中根据图的类型可以分为有向图 dirgraph 和无向图 graph 我们知道图是由点 node 和边 edge 组成的 xff0c 在有向图中边
  • mysqld: File './mysql-bin.index' not found (Errcode: 13 - Permission denied)

    我们通过yum方式安装mysql 会生成mysql mysql用户组和用户 xff0c 启动mysql默认是使用mysql用户 如果我们开启了慢log日志 xff0c 而且我们使用service mysqld start启动mysql 会报
  • redhat7编译安装php-5.5.38

    1 从官网下载php源码包 php 5 5 38 2 安装依赖包 yum install libxml2 libxml2 devel bzip2 devel libcurl devel y yum install openssl opens
  • spark-1.6.0源码编译安装

    环境准备 spark是scala语言写的 xff0c scala运行需要jdk 如果通过maven编译 xff0c 还需要maven环境 xff0c 因此spark源码编译需要安装jdk scala apache maven这三样环境 这里
  • ZendStudio+php+Apache开发环境搭建

    学习php xff0c 我们就想有一个好的ide xff0c ZendStudio是专门为php开发提供的ide xff0c 写完代码立马能够在工作空间中调试 xff0c 可以通过Run As gt PHP CLI Application
  • 图文详解win7实现局域网共享文件

    工作中 xff0c 我们有时候会拥有两台机器 xff0c 避免机器之间文件传来传去 xff0c 可以使用局域网文件共享 xff0c 在一台机器上开启文件共享 xff0c 另一台机器通过IP访问 xff0c 即可轻松实现文件互访 今天介绍我们
  • 模拟画图题P1185 绘制二叉树

    可能更好的观看体验 题目链接P1185 绘制二叉树 题意概述 根据规则绘制一棵被删去部分节点的满二叉树 节点用 o o o 表示 xff0c 树枝用 表示 每一层树枝长度会变化 xff0c 以满足叶子结点有如下特定 xff1a 相邻叶子节点
  • win7+MySQL5.7.18zip版本安装

    mysql5 7 18zip版本在windows的安装 xff0c 就是解压 xff0c 初始化 xff0c 然后做一些密码修改的设置即可使用 xff0c 如果需要远程连接 xff0c 需要更改用户表的host值为 39 39 xff0c
  • redhat7源码编译hadoop2.6.0

    以前在32位linux机器上编译过hadoop2 6 0 这次在redhat7 64bit上再次编译hadoop2 6 0 xff0c 除必须的jdk maven protobuf需要安装之外 xff0c 还需要安装系统依赖库gcc gcc

随机推荐

  • elasticsearch启动错误

    最近想尝试一下elk搭建实时日志分析系统 xff0c 结果运行elasticsearch时 xff0c 就遇到了一些问题 这些问题基本都是系统参数相关的 现在整理出来 xff0c 以免后面再次遇到 xff0c 也供大家参考 xff0c 少走
  • kafka+flume+hdfs实时日志流系统初探

    本次实验 xff0c 主要为了测试将kafka的消息通过flume接收并存入hdfs xff0c 如果之前搭建过hadoop flume kafka的 xff0c 这里会很快就会完成 xff0c 思路比较清晰 xff0c 主要配置在flum
  • 让Eclipse中spring的xml配置文件出现属性和类提示

    在spring配置文件中可以让配置bean的时候出现提示 xff0c 这里需要做一些设置 设置包括安装springide插件 spring beans version xsd文件引入 xff0c 增加xml编辑提示的字符 xff0c 默认只
  • win7查看端口占用的进程

    之前遇到一个问题 xff0c 系统上mysql启动了 xff0c 无法通过navicat客户端来连接 xff0c 这就很郁闷了 xff0c 最后定位到问题 xff0c 是我机器上还开启了一个开发php的应用程序phpwamp 它自带了一个m
  • cxf+spring实现webservice

    1 构建maven项目 xff0c 工程结构如下 xff1a 这里需要特别指出就是cxf core 3 1 12 jar类路径META INF cxf下有一个cxf xml的配置文件 xff0c 这个在applicationContext
  • Activemq+spring整合

    activemq与spring的整合需要用到线程池 考虑到连接 会话等资源的建立和释放 xff0c 无须人工操作 xff0c 全部交给容器来处理 这里通过一个实例讲解activemq与spring如何整合 项目大致是这样的设计 xff1a
  • springsecurity4.2入门完整实例

    1 构建maven项目 xff0c 引入springsecurity相关依赖 项目结构如下 xff1a pom xml配置文件主要部分 xff1a lt properties gt lt spring version gt 4 2 0 RE
  • Linux上tensorflow安装

    选择安装Anaconda xff0c 然后激活tensorflow 环境 最后使用pip install安装 第一步 xff1a 安装Anaconda xff0c Anaconda集成了很多python库 xff0c 不用手动额外安装 An
  • Window安装Anaconda后,conda不是内部或者外部命令

    今天在安装Theano的时候 xff0c 需要看一下 xff0c anaconda已经安装了哪些包 使用命令如下 在控制台 xff0c cmd回车输入即可 xff1a conda list 但是 xff0c 显示出错 xff0c conda
  • zookeeper集群环境搭建

    zookeeper是一个分布式框架 xff0c 它的用途在今天非常广泛 xff0c 通常与dubbo一起构成分布式系统 xff0c 另外kafka消息系统也自带了zookeeper hadoop集群也少不了zookeeper xff0c z
  • hadoop-2.8.0完全分布式环境搭建

    一 机器及环境准备 1 jdk安装不用多说 xff0c 安装完成配置环境变量即可 export JAVA HOME 61 usr java latest export JRE HOME 61 JAVA HOME jre export CLA
  • Your password does not satisfy the current policy requirements解决办法

    mysql5 7 x安装以后 xff0c 想修改随机生成的密码为简单容易记忆的密码 xff0c 如root 123456等 xff0c 这时候通过修改密码的几种方式都不行 xff0c 出现密码不符合当前安全策略要求 为了解决这种问题 xff
  • redhat7安装oracle11gR2之环境准备

    redhat7安装oracle11gR2环境准备 xff1a 内存 xff1a 2g 磁盘空间 xff1a 15g以上 交换分区 xff1a 3g 我们将oracle安装到 opt app oracle目录下 xff0c 后面的环境变量则以
  • redhat7安装oracle11gR2之动手安装

    oracle11gR2 64位数据库下载地址 xff1a http www oracle com technetwork database enterprise edition downloads 112010 linx8664soft 1
  • redhat7静默安装oracle11gR2

    所谓的静默安装是指不用安装redhat7桌面系统 xff0c 并进入桌面利用界面安装oracle xff0c 这里采用最小化安装redhat7 xff0c 直接在命令行下通过命令执行安装 环境配置和用户设置基本和界面安装一致 就是进入 op
  • docker+nextcloud搭建个人云存储系统

    一 docker安装和启动 yum install epel release yum install docker service docker start 二 docker compose安装 curl L http github com
  • kafka集群搭建以及运行kafka监控平台kmonitor

    kafka集群搭建 kafka依赖zookeeper运行 xff0c 在搭建kafka系统之前需要搭建zookeeper集群 xff0c 这里先略过zookeeper集群搭建的过程 另外 xff0c kafka需要运行在jdk环境中 xff
  • CDH5安装失败如何重新安装

    cdh安装失败的原因可能有以下原因 xff1a 1 机器内存不足 xff0c server节点我用了6G xff0c 两个agent节点均是4G才安装成功 2 需要的mysql驱动文件没有拷贝到指定位置 具体重新安装步骤如下 xff1a 一
  • nginx日志切割和日志定期清理

    nginx日志默认不做人为处理 xff0c 日志文件会存放在access log error log两个文件中 xff0c 随着时间的推移 xff0c 日志量会越来越大 xff0c 不方便编辑查看 xff0c 为了让日志按天存放 xff0c
  • 结构体(参数、嵌套)、结构体指针、结构体中const的使用场景

    结构体 xff1a 属于用户自定义的数据类型 xff0c 允许用户存储不同的数据类型 xff1b 结构体定义和使用 通过结构体创建变量的方式有三种 xff1a struct 结构体名 变量名struct 结构体名 变量名 61 成员1 xf