關于結構體里面結構體的申明和使用

?

申請:

?

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.pswp.cn/news/256369.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/256369.shtml
英文地址,請注明出處:http://en.pswp.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…