关于结构体里面结构体的申明和使用

 

申请:

 

typedef struct Vo{int Voltage;float Delay_ms;char Enable;}Volt_Def;typedef struct ed{float Delay_ms;int Level;}Edge_Def;typedef struct Ed_hard{Edge_Def a;Edge_Def b;Edge_Def c;}HARD_RESET;int power_sel = 0xff;typedef struct power_x{Volt_Def *VO_One=new Volt_Def;Volt_Def *VO_Two=new Volt_Def;Volt_Def *VO_Three=new Volt_Def;Volt_Def *VO_Four=new Volt_Def;Volt_Def *VO_Five=new Volt_Def;Volt_Def *VO_Six=new Volt_Def;Volt_Def *VSP=new Volt_Def;Volt_Def *VSN=new Volt_Def;HARD_RESET *TP_RESET=new HARD_RESET;HARD_RESET *LCD_RESET=new HARD_RESET;HARD_RESET *DPHY_POWER=new HARD_RESET;HARD_RESET *DPHY_RESET=new HARD_RESET;}Power_XX;Power_XX Power_up, Power_down;

 

 

 

使用:

  Power_up.VO_One->Voltage=strtoul(VO1->GetText(), NULL, 0);

参考:(下面为摘抄)

 一.new的用法:

1. new() 分配这种类型的一个大小的内存空间,并以括号中的值来初始化这个变量;

2. new[]
分配这种类型的n个大小的内存空间,并用默认构造函数来初始化这些变量;

char * p=new char("Hello");

char* p=new char[6];

//p="Hello";

3.开辟单变量地址空间

1)new int; //开辟一个存放数组的存储空间,返回一个指向该存储空间的地址.int *a = new int
即为将一个int类型的地址赋值给整型指针a.

2)int *a = new int(5)
作用同上,但是同时将整数赋值为5

4.开辟数组空间

一维: int *a = new
int[100];开辟一个大小为100的整型数组空间

二维: int **a = new
int[5][6]

三维及其以上:依此类推.

一般用法: new 类型 [初值]

5.
当使用new运算符定义一个多维数组变量或数组对象时,它产生一个指向数组第一个元素的指针,返回的类型保持了除最左边维数外的所有维数。例如:

int
*p1 = new int[10];

返回的是一个指向int的指针int*

int (*p2)[10] = new
int[2][10];

new了一个二维数组, 去掉最左边那一维[2], 剩下int[10],
所以返回的是一个指向int[10]这种一维数组的指针int (*)[10].

int (*p3)[2][10] = new
int[5][2][10]; new了一个三维数组, 去掉最左边那一维[5], 还有int[2][10],
所以返回的是一个指向二维数组int[2][10]这种类型的指针int
(*)[2][10].

例子:

#include

#include

using namespace
std;

int main() {

int *a = new int[34];

int *b = new
int[];

int (*c)[2] = new int[34][2];

int (*d)[2] = new
int[][2];

int (*e)[2][3] = new int[34][2][3];

int (*f)[2][3] = new
int[][2][3];

a[0] = 1;

b[0] = 1;
//运行时错误,无分配的内存,b只起指针的作用,用来指向相应的数据

c[0][0] = 1;

d[0][0] = 1;
//运行时错误,无分配的内存,d只起指针的作用,用来指向相应的数据

e[0][0][0] = 1;

f[0][0][0] = 1;
//运行时错误,无分配的内存,f只起指针的作用,用来指向相应的数据

cout<<typeid(a).name()<<endl;

cout<<typeid(b).name()<<endl;

cout<<typeid(c).name()<<endl;

cout<<typeid(d).name()<<endl;

cout<<typeid(e).name()<<endl;

cout<<typeid(f).name()<<endl;

delete[]
a; delete[] b; delete[] c;

delete[] d; delete[] e; delete[]
f;

}

输出结果:

int *

int *

int (*)[2]

int
(*)[2]

int (*)[2][3]

int
(*)[2][3]



6.new运算符

最常用的是作为运算符的new,比如:

string *str =
new string(“test new”);

作为运算符,new和sizeof一样,是C
内置的,你不能对它做任何的改变,除了使用它。

new会在堆上分配一块内存,并会自动调用类的构造函数。

7.new函数

第二种就是new函数,其实new运算符内部分配内存使用的就是new函数,原型是:

void
*operator new(size_t
size);

new函数返回的是一个void指针,一块未经初始化的内存。如你所见,这和C语言的malloc行为相似,你可以重载new函数,并且增加额外的参数,但是必须保证第一个参数必须是size_t类型,它指明了分配内存块的大小,C
允许你这么做,当然一般情况下这是不必要的。如果重载了new函数,在使用new操作符时调用的就是你重载后的new函数了。

如果使用new函数,和语句string
*str = new string(“test new”)相对的代码大概是如下的样子:

1. string *str =
(string*)operator new(sizeof(string));

2. str.string(“test
new”);

3. //
当然这个调用时非法的,但是编译器是没有这个限制的

这还不算完,还有第三种的new存在。

8.placement
new

第三种,placement
new,这也是new作为函数的一种用法,它允许你在一块已存在的内存上分配一个对象,而内存上的数据不会被覆盖或者被你主动改写,placement
new同样由new操作符调用,调用格式是:

new (buffer) type(size_t
size);

先看看下面的代码:

4. char str[22];

5. int data =
123;

6. int *pa = new (&data) int;

7. int *pb = new (str)
int(9);

结果*pa = 123(未覆盖原数据),而*pb = 9(覆盖原数据),可以看到placement new
并没有分配新的内存,也可以使用在栈上分配的内存,而不限于堆。

为了使用placement new
你必须包含或者

其实placement new和第二种一样,只不过多了参数,是函数new的重载,语法格式为:

void
*operator new(size_t, void* buffer);

它看起来可能是这个样子:

void *operator
new(size_t, void* buffer) { return
buffer;}

和new对应的就是delete了,需要回收内存啊,不然就泄漏了,这个下次再写吧,回忆一下今天的内容先。

二.delete用法:

1.
int *a = new int;

delete a; //释放单个int的空间

2.int *a = new
int[5];

delete [] a;
//释放int数组空间

要访问new所开辟的结构体空间,无法直接通过变量名进行,只能通过赋值的指针进行访问.

用new和delete可以动态开辟,撤销地址空间.在编程序时,若用完一个变量(一般是暂时存储的数组),下次需要再用,但却又想省去重新初始化的功夫,可以在每次开始使用时开辟一个空间,在用完后撤销它.



总结

1.
函数new

void *operator new(size_t size); 在堆上分配一块内存,和placement new(void
*operator new(size_t, void* buffer)); 在一块已经存在的内存上创建对象,如果你已经有一块内存,placement
new会非常有用,事实上,它STL中有着广泛的使用。

2. 运算符new

最常用的new,没什么可说的。

3.
函数new不会自动调用类的构造函数,因为它对分配的内存类型一无所知;而运算符new会自动调用类的构造函数。

4.
函数new允许重载,而运算符new不能被重载。

 

转载于:https://www.cnblogs.com/xifengib/p/5882555.html

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

面试题(十四)

唐巧前辈说这些都是 iOS 的基础问题&#xff0c;应该对此深入的了解。当初看到时&#xff0c;大部分回答不上来&#xff0c;因为平时没有好好思考整理过。这里大部分的概念大多会在学习 OC 的过程中遇到过&#xff0c;但还是得经过写代码才能有更深的理解。反正我当初看那些设计…

工业相机基础知识详述 —— 焦平面,像平面,弥散圆,光圈,分辨率,景深,接口,靶面尺寸

一、焦平面 想到焦平面&#xff0c;很多人不由自主就想到不就是焦点所在的垂直于光轴的平面吗&#xff1f;其实其背后隐藏这更多的东西。 1&#xff09;焦点不止一个 对于一般拍摄场景来说&#xff0c;光通过一个凸透镜&#xff0c;汇聚不到一个点&#xff0c;越靠近中轴线的…

机器学习——SVM之交叉验证对参数(C,gamma)进行优化以及选择

目录 一、(C,gamma)简介 二、交叉验证 1、什么是交叉验证? 2、参数优化方法

【BZOJ-2427】软件安装 Tarjan + 树形01背包

2427: [HAOI2010]软件安装 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 960 Solved: 380[Submit][Status][Discuss]Description 现在我们的手头有N个软件&#xff0c;对于一个软件i&#xff0c;它要占用Wi的磁盘空间&#xff0c;它的价值为Vi。我们希望从中选择一些软件…

Hadoop目录

1. 通过java读取HDFS的数据 (转&#xff09; 2. FLume监控文件夹&#xff0c;将数据发送给Kafka以及HDFS的配置文件详解 3. 开启hadoop和Hbase集群的lzo压缩功能&#xff08;转&#xff09; 4. Hadoop集群WordCount运行详解&#xff08;转&#xff09;转载于:https://www.cnblo…

相机标定(二)深入理解四大坐标系与其变换关系

一、前言 视觉系统一共有四个坐标系&#xff1a;像素平面坐标系&#xff08;u,v&#xff09;、图像坐标系&#xff08;x,y&#xff09;、相机坐标系&#xff08;Xc,Yc,Zc&#xff09;和世界坐标系&#xff08;Xw,Yw,Zw&#xff09;&#xff0c;如下图所示。每种坐标系之间均存…

numpy——ravel()和flatten()

目录 功能 用法 区别 flatten&#xff08;&#xff09; ravel() 功能 这两个函数的功能都是将多维数组转换成一维 用法 import numpy as np arr np.array([[1, 2],[3, 4]]) arr.flatten()降维默认行序优先&#xff0c;传入参数‘F’表示列序优先 arr.flatten(F) arr.r…

Django的model中日期字段设置默认值的问题

之前写过这样一个model&#xff1a; class MonthlyFeeMember(models.Model):worker models.ForeignKey(Student, verbose_nameu"worker", related_name"as_monthly_fee_members")month models.CharField(umonth, max_length10, defaultget_current_month…

相机标定(三) —— 畸变校正

一、前言 根据针孔模型&#xff0c;物体和成像之间参数会满足相似三角形的关系。但现实中会存在装配误差和透视失真等原因&#xff0c;导致这种关系无法成立&#xff0c;使理想成像与实际成像存在误差&#xff0c;这种误差即称为畸变。 畸变分为径向畸变&#xff0c;切向畸变和…

SVG技术入门:线条动画实现原理

相信大家都见到过这样神奇的技术&#xff1a;一副线条构成的画能自动画出自己。非常的酷。Jake Archibald是这种SVG技术的首创者&#xff0c;并且写了一篇非常好的文章来描述它是如何实现的。Brian Suda也在24 Ways网站上讨论过它。 Polygon使用它在一篇设计方面的文章里创造出…

机器学习——人工神经网络之BP算法编程(python二分类数据集:马疝病数据集)

目录 一、理论知识回顾 1、神经网络模型 2、明确任务以及参数 1&#xff09;待估参数&#xff1a; 2&#xff09;超参数&#xff1a; 3&#xff09;任务 3、神经网络数学模型定义 1&#xff09;激活函数 ​ 2&#xff09;各层权重、阈值定义 3&#xff09;各层输入输…

Halcon例程(基于多个标定图的单目相机标定)详解—— Camera_calibration_multi_image.hdev

一、前言 在我的工业相机专栏里已经将相机标定涉及到的理论部分讲解完毕&#xff0c;为什么要标定以及标定要求出什么参数呢&#xff0c;用一个Halcon 例程来帮助理解。 这个例程是比较经典的标定程序&#xff0c;基本将标定过程讲的比较清楚&#xff0c;用的标定图像是系统自…

SkipList 跳表

为什么选择跳表 目前经常使用的平衡数据结构有&#xff1a;B树&#xff0c;红黑树&#xff0c;AVL树&#xff0c;Splay Tree, Treep等。 想象一下&#xff0c;给你一张草稿纸&#xff0c;一只笔&#xff0c;一个编辑器&#xff0c;你能立即实现一颗红黑树&#xff0c;或者AVL树…

Redis failover过程

在Leader触发failover之前&#xff0c;首先wait数秒(随即0~5)&#xff0c;以便让其他sentinel实例准备和调整。如果一切正常&#xff0c;那么leader就需要开始将一个salve提升为master&#xff0c;此slave必须为状态良好(不能处于SDOWN/ODOWN状态)且权重值最低(redis.conf中)的…

机器学习——深度学习之卷积神经网络(CNN)——LeNet卷积神经网络结构

目录 一、卷积神经网络 1、卷积神经的作用 2、LeNet 1&#xff09;数据库准备——minst 2&#xff09;模型 二、关于卷积神经网络结构的一些术语定义 1、特征图&#xff08;Feature map&#xff09; 2、height&#xff08;长度&#xff09;、width&#xff08;宽度&…

工业相机(3D)主要参数详述

一、前言 准确的完成相机选型是一个视觉工程师必备的技能&#xff0c;而选型前必须对其内部参数了如指掌。工业相机是一种比较复杂的产品&#xff0c;其参数很多&#xff0c;每个参数可能会有不同的标准&#xff0c;下面对主要的参数会做比较详细的阐述。 二、参数详述 2.1 …

JAVA8永久代

在Java虚拟机&#xff08;以下简称JVM&#xff09;中&#xff0c;类包含其对应的元数据&#xff0c;比如类的层级信息&#xff0c;方法数据和方法信息&#xff08;如字节码&#xff0c;栈和变量大小&#xff09;&#xff0c;运行时常量池&#xff0c;已确定的符号引用和虚方法表…

Struts 2初体验

Struts2简介&#xff1a; Struts2是一个基于MVC设计模式的Web应用框架&#xff0c;它本质上相当于一个servlet&#xff0c;在MVC设计模式中&#xff0c;Struts2作为控制器(Controller)来建立模型与视图的数据交互。 Struts 2 目录结构:     apps目录&#xff1a;Struts2示例…

机器学习——深度学习之数据库和自编码器

目录 一、数据库——数据获取 1、Mnist 2、ImageNet 二、自编码器&#xff08;Auto-encoder&#xff09;——参数初始化 1、功能 2、基本思想 1&#xff09;训练第一层 2&#xff09;训练第二层及以后的神经网络 ​ 3&#xff09;利用BP对整个神经网络的参数初始值进…

Halcon例程详解 (深度图转换为3D图像)—— xyz_attrib_to_object_model_3d

一、前言 深度图向点云图进行转换是进行3D检测项目时会遇到的问题&#xff0c;halcon里也有针对此问题的相关例程&#xff0c;下面对此例程进行分析。通过学习此例程&#xff0c;我们可以掌握如何将一张深度图像和一张正常二维图像转换为3D点云。 二、分析 * 初始化界面 dev…