通常,new 负责在堆(heap)中找到一个足以能够满足要求的内存块。new 运算符还有另一种变体,被称为定位(placement)new运算符,它让您能够指定要使用的位置。程序员可能使用这种特性来设置其内存管理规程、处理需要通过特定地址进行访问的硬件或在特定位置创建对象。
*# 3.下面是一个结构声明:
struct chaff {
char dross[20];
int slag;
};
编写一个程序,使用定位 new运算符将一个包含两个这种结构的数组放在一个缓冲区中。
然后,给结构的成员赋值(对于char 数组,使用函数 strcpy()),并使用一个循环来显示内容。
一种方法是像程序清单9.10那样将一个静态数组用作缓冲区;另一种方法是使用常规new运算符来分配缓冲区。
#pragma region 第九章练习3
/*
*# 3.下面是一个结构声明:
struct chaff {
char dross[20];
int slag;
};
编写一个程序,使用定位 new运算符将一个包含两个这种结构的数组放在一个缓冲区中。
然后,给结构的成员赋值(对于char 数组,使用函数 strcpy()),并使用一个循环来显示内容。
一种方法是像程序清单9.10那样将一个静态数组用作缓冲区;另一种方法是使用常规new运算符来分配缓冲区。
*/
#if 1
#include<iostream>
struct chaff
{
char dross[20];
int slag;
};
using namespace std;
char buffer[512];
//static char buffer[512];
int main(void)
{
//char buffer[512];
//static char buffer[512];
chaff* pChaff = new(buffer)chaff[2];
const char* ch1 = "Phone";
const char* ch2 = "Number";
chaff* pch = new chaff[2];
strcpy_s(pChaff[0].dross, strlen(ch1) + 1, ch1);
pChaff[0].slag = 1075;
strcpy_s(pChaff[1].dross, strlen(ch2) + 1, ch2);
pChaff[1].slag = 1167;
strcpy_s(pch[0].dross, strlen(ch1) + 1, ch1);
pch[0].slag = 1075;
strcpy_s(pch[1].dross, strlen(ch2) + 1, ch2);
pch[1].slag = 1167;
cout << "pch,&pch " << pch <<"\t" << &pch << endl;
cout << "pChaff,&pchar " << pChaff << "\t" << &pChaff << endl;
for (int i = 0; i < 2; i++)
{
cout << pChaff[i].dross << "\t" << pChaff[i].slag << endl;
}
cout << endl;
delete[] pch;
return 0;
}
#endif
#pragma endregion
这里添加了一段new常规方法分配内存作比较的,处于学习的目的,更改了cha r buffer数组的位置,