博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
C++11:POD数据类型
阅读量:5142 次
发布时间:2019-06-13

本文共 2992 字,大约阅读时间需要 9 分钟。

版权声明:本文为博主原创文章。未经博主同意不得转载。 https://blog.csdn.net/aqtata/article/details/35618709

啥是POD类型?

POD全称Plain Old Data。通俗的讲,一个类或结构体通过二进制拷贝后还能保持其数据不变,那么它就是一个POD类型。

平庸的定义

1.有平庸的构造函数

2.有平庸的拷贝构造函数

3.有平庸的移动构造函数

4.有平庸的拷贝赋值运算符

5.有平庸的移动赋值运算符

6.有平庸的析构函数

7.不能包括虚函数

8.不能包括虚基类

#include "stdafx.h"#include 
using namespace std;class A { A(){} };class B { B(B&){} };class C { C(C&&){} };class D { D operator=(D&){} };class E { E operator=(E&&){} };class F { ~F(){} };class G { virtual void foo() = 0; };class H : G {};class I {};int _tmain(int argc, _TCHAR* argv[]){ std::cout << std::is_trivial
::value << std::endl; // 有不平庸的构造函数 std::cout << std::is_trivial::value << std::endl; // 有不平庸的拷贝构造函数 std::cout << std::is_trivial
::value << std::endl; // 有不平庸的拷贝赋值运算符 std::cout << std::is_trivial
::value << std::endl; // 有不平庸的拷贝赋值运算符 std::cout << std::is_trivial
::value << std::endl; // 有不平庸的移动赋值运算符 std::cout << std::is_trivial
::value << std::endl; // 有不平庸的析构函数 std::cout << std::is_trivial
::value << std::endl; // 有虚函数 std::cout << std::is_trivial
::value << std::endl; // 有虚基类 std::cout << std::is_trivial
::value << std::endl; // 平庸的类 system("pause"); return 0;}
执行结果

标准布局的定义

1.全部非静态成员有同样的訪问权限

2.继承树中最多仅仅能有一个类有非静态数据成员

3.子类的第一个非静态成员不能够是基类类型

4.没有虚函数

5.没有虚基类

6.全部非静态成员都符合标准布局类型

#include "stdafx.h"#include 
using namespace std;class A { private: int a;public: int b;};class B1{ static int x1;};class B2{ int x2;};class B : B1, B2{ int x;};class C1 {};class C : C1{ C1 c;};class D { virtual void foo() = 0; };class E : D {};class F { A x; };int _tmain(int argc, _TCHAR* argv[]){ std::cout << std::is_standard_layout
::value << std::endl; // 违反定义1。

成员a和b具有不同的訪问权限 std::cout << std::is_standard_layout<B>::value << std::endl; // 违反定义2。继承树有两个(含)以上的类有非静态成员 std::cout << std::is_standard_layout<C>::value << std::endl; // 违反定义3。第一个非静态成员是基类类型 std::cout << std::is_standard_layout<D>::value << std::endl; // 违反定义4。有虚函数 std::cout << std::is_standard_layout<E>::value << std::endl; // 违反定义5。有虚基类 std::cout << std::is_standard_layout<F>::value << std::endl; // 违反定义6。

非静态成员x不符合标准布局类型 system("pause"); return 0; }

执行结果

POD的使用

当一个数据类型满足了”平庸的定义“和”标准布局“。我们则觉得它是一个POD数据。

能够通过std::is_pod来推断一个类型是否为POD类型。

如文章开头说的。一个POD类型是能够进行二进制拷贝的。看看以下的样例。

#include "stdafx.h"#include 
#include
using namespace std;class A { public: int x; double y;};int _tmain(int argc, _TCHAR* argv[]){ if (std::is_pod
::value) { std::cout << "before" << std::endl; A a; a.x = 8; a.y = 10.5; std::cout << a.x << std::endl; std::cout << a.y << std::endl; size_t size = sizeof(a); char *p = new char[size]; memcpy(p, &a, size); A *pA = (A*)p; std::cout << "after" << std::endl; std::cout << pA->x << std::endl; std::cout << pA->y << std::endl; delete p; } system("pause"); return 0;}
执行结果

能够看到。对一个POD类型进行二进制拷贝后,数据都成功的迁移过来了。

转载于:https://www.cnblogs.com/xfgnongmin/p/10669970.html

你可能感兴趣的文章
Streaming的receiver模式
查看>>
[转载]一个人的失败,99%失败于“脾气”
查看>>
【Nowcoder】玩游戏
查看>>
过滤器(Filter)
查看>>
字符串的操作
查看>>
性能优化之Java(Android)代码优化
查看>>
springMVC相关—文件上传
查看>>
由Oracle 11g SYSAUX 和 SYSTEM 表空间回收引发的联想
查看>>
uva 1416 Warfare And Logistics
查看>>
欲则不达
查看>>
盒子游戏
查看>>
OpenJudgeP1.10.08:病人排队__(刷题)_水题
查看>>
观察者模式
查看>>
Hadoop分布式文件系统中架构和设计要点汇总
查看>>
cout和printf
查看>>
UVa 10088 - Trees on My Island (pick定理)
查看>>
#C++PrimerPlus# Chapter11_Exersice4_mytimeV4
查看>>
iOS8 针对开发者所拥有的新特性汇总如下
查看>>
Jmeter + Grafana搭建实时监控可视化
查看>>
uCGUI字符串显示过程分析和uCGUI字库的组建
查看>>