c++,new,delete,成员指针

new和delete用来申请动态内存空间,一定要配对使用

#include <string>    
#include <ctype.h>
#include <vector>
#include <iostream>  
#include <fstream>


// using declarations states our intent to use these names from the namespace std    
using namespace  std;

int main()
{
    int *p = static_cast<int*>(malloc(sizeof(int))); 
    //对于内置类型,如int,double,float,char...即使不用new声明,使用delete释放也不会出任何编译,运行错误,但是对于任何类类型,不管是自定义还是系统自带的,都会出错误
//队伍malloc分配后用delete释放,我进内存看过,可以正常的释放掉内存中的数据,完全可行
int s = 1;
int *s = &s;
delete s; //飘红的这三行可以编译通过,运行也没问题,但是,调试的时候会出错,千万不要这样做!!! int *p_new = new int; //分配一个int类型的地址空间,不进行初始化 int *p_new_1 = new int(10);//初始化为10 int n = 10;//如果n过大,会导致内存申请失败抛出错误,如果不想抛出错误可以再new后面加上nothrow
//为什么说是动态分配内存,因为n是变量,是不确定的,所以每次分配的内存不确定,是在运行时分配 char *p_new_array = new(nothrow) char[n];//对于内置类型,n为0时这样写没问题,而且可以进行解引用,并且直接delete不用数组括号也行 string *p_new_string = new string[n];//n为0时无法进行解引用,会报错,不加括号的delete出错,也不能进行解引用。 cout << *p << endl; cout << *p_new << endl; cout << *p_new_1 << endl; cout << *p_new_array << *(p_new_array+1) << endl; //delete p;// 基本内置类型可以,对于类类型这样不行,因为不是用new声明的 delete p_new;p_new=null;//将悬空指针变为空指针 delete p_new_1; p_new_1=null; delete p_new_array; p_new_array=null;//错误的写法,只对基本内置类型有效 delete[]p_new_string; //正确的写法,要和相应的new配对 return 0; }

成员地址,是相对于开始地址的相对偏移。

#include <string>    
#include <ctype.h>
#include <vector>
#include <iostream>  
#include <fstream>
#include<new>


// using declarations states our intent to use these names from the namespace std    
using namespace  std;
struct Date
{
    int year;
    int month;
    int day;
    void print(){ cout << year << "-" << month << "-" << day << endl; }
};

void showYear(Date a[], int length, int Date::*year);
int main()
{
    Date a[5] = { { 2001, 1, 1 }, { 2002, 2, 2 }, { 2003, 3, 3 }, { 2004, 4, 4 }, { 2005, 5, 5 } };
    Date d = { 1997, 7, 9 };
    cout << "&d = " << &d << endl;
    cout << "&d.year = " << &d.year << " &d.month = " << &d.month << " &d.day =" << &d.day << endl; //绝对地址
    cout << &Date::year << &Date::month << &Date::day << endl;//成员地址打印出来是111,c++认为成员地址和函数地址无意义,所以都直接处理为true,在输出也就显示为1
    //cout << static_cast<int*>(&Date::year) << endl; //那么,强转来看看地址,结果报错,不能转换
    //匿名联合,两个变量同用同一个空间
    union 
    {
        int n;
        int Date::*mp;
    };
    mp = &Date::day;
    cout << "n = " << n << endl;//输出8,相对于year的地址
    //通过成员地址来访问结构中的成员
    cout << d.*mp << endl;

    //应用,访问a数组中的,所有日期中的年份
    showYear(a, sizeof(a)/sizeof(Date), &Date::year);

    //成员函数指针
    d.print();
    void (Date::*p)() = &Date::print;
    (d.*p)();
    return 0;
}

void showYear(Date a[], int length, int Date::*p)//p是date中某个成员的地址,不可用day,year,month,会造成表达模糊
{
    for (int i = 0; i < length;++i)
    {
        cout << a[i].*p << " "; //a[i].year表达不出我想要用成员地址的意愿,因为year本来就是成员
        //p是成员地址,*p是结构中的某个成员,a[i].*p,取出这个成员
    }
    cout << endl;
}