首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

C++使用new来初始化指向类的指针

C++使用new来初始化类的指针 1.ClassName * p = new ClassName; 调用默认构造函数。...C++指针初始化问题 c++中的指针是一个很经典的用法,但是也是最容易出错的,比如定义了一个指针,必须对其进行初始化,不然这个指针指向的是一个未知的内存地址,后续对其操作的时候,会报错。...下面就总结一下c++指针初始化的一些方法,以及我自己遇到的一些问题以及心得体会。...c++指针初始化的一般方法 1.将一个已经在内存中存在变量的地址传递给定义的指针 这个指针就指向这个变量的内存地址(相同的数据类型),完成初始化。...自己遇见的问题 我在使用结构体指针的时候,忘记将结构体指针初始化,导致后面访问结构体成员变量的时候出现错误(那种编译没错,执行出错的问题),后来将指针使用new初始化解决,还有一点就是,全局的变量名称与局部变量名称不要一样

53720
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    C++ this指针:用于在成员函数中指向调用该函数的对象

    C++中this指针是一个指向当前对象的指针。在成员函数中,可以使用this指针来访问调用该函数的对象的成员变量和成员函数。...一、定义和使用this指针 this指针是在成员函数内部定义的一个常量指针。它存储了当前对象的地址,可以通过它访问当前对象的成员变量和成员函数。...二、作为返回值的this指针 this指针可以作为返回值返回。这种情况下,返回的是指向调用该函数的对象的指针。为了实现这个功能,需要将返回类型设置为类的引用或指针类型。...,返回的是指向调用该函数的对象的指针。...四、总结 this指针在C++中是一个非常重要的概念,可以用来访问调用该函数的对象,作为返回值返回,或者作为函数参数传递。掌握this指针的使用可以帮助我们更好地编写面向对象的程序。

    26040

    c++系列之二 指向成员函数的指针(烧脑)

    ,原文详细解释了C++中指向成员函数的指针,因为带有“教程”一词,所以比较通俗易懂。...如果对翻译君的翻译质量有意见,建议前往 原地址 围观。 咦?还不走?那废话少说,我们开始了啊。 关于成员函数指针 成员函数指针是C++最少用到的语法之一,甚至有经验的C++码农有时候也会被它搞晕。...“高大上”的 fptr : fptr = &Foo::f; 当然,就连脑残都知道可以将声明和初始化结合起来: int (Foo::*fptr) (string) = &Foo::f; 为了通过函数指针来调用成员函数...这个例子证明了成员函数指针不是常规指针。另外,为什么C++如此费心地去发明这样的语法?很简单,因为它和常规指针是不同的东西,而且这样的类型转换也是违反直觉的。...因为 “一个指向虚成员的指针能在不同地址空间之间传递,只要二者使用的对象布局一样” (此话来自C++老爸 Bjarne Stroustrup 的 《C++程序设计语言》 )。

    3.1K20

    函数申明对函数模板实例化的屏蔽

    1.C++函数匹配顺序 C++语言引入模板机制后,函数调用的情形显的比C语言要复杂。当发生一次函数调用时,如果存在多个同名函数,则C++编译器将按照如下的顺序寻找对应的函数定义。...(1)寻找一个参数完全匹配的函数,如果找到了就调用它。 (2)寻找一个函数模板,并根据调用情况进行参数推演,如果推演成功则将其实例化,并调用相应的模板函数。...函数申明对函数模板实例化的屏蔽 如果使用了函数申明,可能会造成对函数模板实例化的屏蔽。考察如下程序。...这种现象,可以把它叫做函数申明对函数模板实例化的屏蔽。其本质是,在发生函数调用的时候,编译器总是优先调用普通函数而不是函数模板。要解决这个问题,可以采取以下三种办法。 (1)去掉函数申明。...(const T&);这样就会启用函数模板的实例化。

    61520

    【C++】构造函数初始化列表 ① ( 类对象作为成员变量时的构造函数问题 | 构造函数初始化列表语法规则 )

    就是 C++ 中的 构造函数 初始化列表 ; 2、错误代码示例 代码示例 : #include "iostream" using namespace std; class A { public: /...========== 生成: 成功 0 个,失败 1 个,最新 0 个,跳过 0 个 ========== 二、构造函数初始化列表 ---- 1、构造函数初始化列表语法规则 在 C++ 语言中 , 构造函数初始化列表...是一种用于初始化类的成员变量的方法 ; 构造函数初始化列表 可实现功能 : 为成员变量提供初始值 调用其他 成员变量的 构造函数 来初始化成员变量 构造函数初始化列表语法规则 : 构造函数() : 成员变量名称...初始化列表中的元素由 成员变量的名称 和 初始值组成 , 使用等号 = 连接 ; 在下面的代码中 , 为 B 类定义了默认的构造函数 , 其中定义了 构造函数 初始化列表 ; 在 初始化列表中 , m_age...(10, 150) {} public: int m_age; // 年龄 A m_a; // A 类型成员变量 }; 2、代码示例 - 构造函数初始化列表语法规则 代码示例 : #include

    67630

    【C++】构造函数初始化列表 ③ ( 构造函数 的 初始化列表 中 为 const 成员变量初始化 )

    构造函数初始化列表 总结 : 初始化列表 可以 为 类的 成员变量 提供初始值 ; 初始化列表 可以 调用 类的 成员变量 类型的 构造函数 进行成员变量初始化操作 ; 初始化列表 可以 使用 构造函数...中传入的 参数 ; 类初始化时 , 根据定义顺序 , 先调用 成员变量的 构造函数 , 然后调用外部类构造函数 , 析构函数正好相反 ; 实例对象 的 const 成员变量 必须只能在 初始化列表 中进行...初始化 , 所有的构造函数都要进行初始化操作 ; 一、构造函数 的 初始化列表 中 为 const 成员变量初始化 1、初始化 const 常量成员 如果 类 中定义了 被 const 修饰 的 成员变量..., 那么该成员变量 必须被初始化 , 否则会报错 ; 对象中的 const 成员 必须在 声明后 立刻进行初始化 ; const 成员的初始化 只能通过 构造函数 的 初始化列表 进行初始化 ; 注意...进行赋值 的 , 因此 这里 必须在 构造函数的 初始化列表中 对 const 成员变量 进行赋值 ; 2、错误代码示例 - 没有初始化常量成员 在下面的 类 B 中 , 定义了常量 const int

    24230

    C++中关于指针初始化和使用NULL的理解

    1、严禁使用未被初始化的指针:C++创建指针的时候,只分配存储地址的内存,并不会分配存储数据的内存,所以指针可能指向任何位置。   ...(1)使用解除运算符(*)之前,一定要对指针初始化,否则若声明的指针刚好指向程序代码的位置会导致一些很隐蔽的错误。    (2)未被初始化之前禁止指针之间的赋值。...2、对NULL的理解 一开始想不明白:如果给一个指针初始化成NULL之后不是就代表,指针指向一块内存单元了吗,那应该可以直接往里面填值,可是实际却不可以。...首先看一下百科中一段关于NULL的描述: NULL的出现是一种约定俗成,事实上它不是C语言中的关键字;把一个指针赋值为NULL,通常的说法是“将指针悬空”。这样,指针就无法再进行任何数据访问了。...0位置指向的是程序起始,对于不同的编译器,NULL指针的操作结果是不同的:有些是不准读写,有些是只读,甚至读写都允许。编译器是人定的。

    2.8K100

    函数新手的冷门——函数模板(全:包括实例化和具体化)

    定义 函数模板不是一个实在的函数,编译器不能为其生成可执行代码。定义函数模板后只是一个对函数功能框架的描述,当它具体执行时,将根据传递的实际参数决定其功能。 这他妈的,god知道是什么东西啊!...Swap的类型,但是发现,我们传入的n,m都是int类型,所以自己用int来代替函数模板中的T 要实现函数模板的理解,我们还应该了解专业术语: 实例化:1 实例化 实例化有两种形式,分别为显式实例化和隐式实例化...模板并非函数定义,实例式函数定义。 1.1 显式实例化(explicit instantiation) 显式实例化意味着可以直接命令编译器创建特定的实例,有两种显式声明的方式。...1.2 隐式实例化(implicit instantiation) 隐式实例化比较简单,就是最正常的调用,Swap(a,b),直接导致程序生成一个Swap()的实例,该实例使用的类型即参数a和b的类型...显式具体化将不会使用Swap()模板来生成函数定义,而应使用专门为该特定类型显式定义的函数类型。

    45520

    C++对象的初始化和清理之构造函数和析构函数分析与实例(一)

    对象的初始化和清理 生活中我们买的电子产品都基本会有出厂设置,在某一天我们不用时候也会删除一些自己信息数据保证安全 C++中的面向对象来源于生活,每个对象也都会有初始设置以及 对象销毁前的清理数据的设置...构造函数和析构函数 对象的初始化和清理也是两个非常重要的安全问题 ​ 一个对象或者变量没有初始状态,对其使用后果是未知 ​ 同样的使用完一个对象或变量,没有及时清理,也会造成一定的安全问题 c++利用了构造函数和析构函数解决上述问题...对象的初始化和清理工作是编译器强制要我们做的事情,因此如果我们不提供构造和析构,编译器会提供 编译器提供的构造函数和析构函数是空实现。...(); system("pause"); return 0; } PS:匿名对象特点:当行结束立即析构,如下图代码的执行顺序,一般的类在实例化后都是在当前函数执行完成后才析构。...错误:Person (p5);等同于Person p5; 拷贝构造函数调用时机 C++中拷贝构造函数调用时机通常有三种情况 使用一个已经创建完毕的对象来初始化一个新对象 值传递的方式给函数参数传值 以值方式返回局部对象

    62420

    【C++】多态 ⑧ ( 验证指向 虚函数表 的 vptr 指针 | 对比定义了虚函数的类和没有定义虚函数类的大小 )

    对比 定义了 虚函数 的类 与 没有定义虚函数的类 的大小 , 其它成员都相同 , 定义了虚函数的类多出了 4 字节 , 多出的 4 字节就是 vptr 指针占用的内存空间 ; 一、验证指向 虚函数表...的 vptr 指针 是否存在 1、虚函数表与 vptr 指针由来 " 虚函数表 " 由 C++ 编译器 负责 创建 与 维护 , 被 virtual 关键字 修饰的 虚函数 , 会自动 被 C++ 编译器...虚函数指针 : " 虚函数表 " 是 存储 " 类成员函数指针 " 的 数据结构 , 是一个 函数指针数组 , 数组中的元素都是函数指针 , 具体存储的都是 指向 类中的虚函数 的指针 ; 如果 子类...中 , 重写了 父类的 virtual 虚函数 , 那么 C++ 编译器会在 子类 虚函数表 中放入该 子类虚函数的 函数指针 ; 如果 C++ 类中存在 virtual 虚函数 , 在创建对象时 ,...会生成 虚函数表 Virtual Function Table , 简称 vtable ; C++ 编译器 编译 代码时 , 会自动为该类 添加 一个 vptr 指针 成员变量 , 该指针 会指向 虚函数表

    22740

    【c++】模板编程解密:C++中的特化、实例化和分离编译

    这意味着你不能用动态计算的值或者运行时才能得知的值作为非类型模板参数的实参 按需实例化 按需实例化,是 C++ 模板的一个重要特性,指的是模板代码只有在真正被使用时才会被编译器实例化 在 C++ 中,模板本身并不直接生成可执行代码...这就是所谓的按需实例化 比如,对于上面的代码,我在T& operator[]函数中写一个错误的语法: T& operator[](size_t index) { size(1); return...上述示例中,p1指向的d1显然小于p2指向的d2对象,但是Less内部并没有比较p1和p2指向的对象内容,而比较的是p1和p2指针的地址,这就无法达到预期而错误 此时,就需要对模板进行特化。..." int main() { Add(1, 2); Add(1.0, 2.0); return 0; } 存在问题: 在 C++ 中,编译器需要在编译时知道模板函数的完整定义,因为它必须用具体的类型对模板进行实例化...此外,这种显式实例化方式只适用于你能预先知道所需类型的情况,这在泛型编程中并不常见。

    62410

    【C++】类和对象(类的定义,类域,实例化,this指针)

    = 4) { } }; 注意一:也许会遇上如下初始化的时候,capacity(成员变量) = capacity(函数创建的临时变量) 区分方法:定义成员变量可以在变量前加标识符“_” class...Init的初始化谁是谁 size_t _top; //成员函数 void Init(int capacity = 4) { //一目了然,左边是成员变量,右边是函数接收传参的临时变量...实例化 这是我之前写的博客内容 1. 1对N 一个类可以实例化多个对象 2. 计算大小只考虑成员变量 不包含成员函数 计算方式遵循内存对齐原则 内存对齐原则 3....int a = 0, float b = 0, char c = 0)//构造函数,用于初始化对象的成员变量,后续会给大家介绍 { _a = a; _b = b; _c = c; }...该函数调用当中的this指针指向的是对象m,自动访问其地址 注意: 形参和实参传参列表(this指针会自动在参数第一个位置生成)不可直接使用this,仅可在类的成员函数中使用。

    10210

    C++构造函数体内赋值与初始化列表的区别

    Linux环境下,使用g++编译以下使用初始化列表的代码时出现编译错误error: expected '{' before 'this'。...,不能使用this指针,因为对象完成初始化之前,类对象还未成形,以上问题的解决办法就是去掉this。...答案是可以,因为构造函数对成员数据的初始化在是在初始化列表中完成的,构造函数体内对数据成员所做的工作仅仅是赋值操作,在此之前,类成员数据已经完成了初始化工作,是由其默认构造函数完成的。...所以,这也是编程原则中尽量使用初始化列表的原因。...将上面错误代码的类数据成员的初始化改为在构造函数体内赋值,则没有问题,代码修改如下: class someClass { int num; string studentNmae; public:

    1.4K21

    C++构造函数体内赋值与初始化列表的区别

    1.C++构造函数初始化列表处提示出现 error: expected ‘{’ before ‘this’ 问题描述下: Linux环境运行,使用g++编译,贴上如下代码出错处已标注于代码中。...在得知网友点拨后,才知道其原因是类对象完成初始化之前,类对象还未成形,不能使用this指针。以上问题的解决方案就是去掉this。...---- 2.初始化列表中不能使用this,那构造函数体内是否可以使用this呢?...答案是,当然可以,因为构造函数对成员数据的初始化在是在初始化列表中完成的,构造函数体内对数据成员所做的工作仅仅是赋值操作,在此之前,类成员数据已经完成了初始化工作,是由其默认构造函数完成的。...所以,这也是编程原则中尽量使用初始化列表的原因。

    87520

    【C++】继承 ⑥ ( 继承中的构造函数和析构函数 | 类型兼容性原则 | 父类指针 指向 子类对象 | 使用 子类对象 为 父类对象 进行初始化 )

    " 应用场景 : 直接使用 : 使用 子类对象 作为 父类对象 使用 ; 赋值 : 将 子类对象 赋值给 父类对象 ; 初始化 : 使用 子类对象 为 父类对象 初始化 ; 指针 : 父类指针 指向..." << endl; } }; 1、父类指针 指向 子类对象 定义 一个子类对象 Child child ; 定义父类的指针 , 将 指针 指向 子类对象 的地址 , 这是合法的 ; 代码示例...); } 2、使用 子类对象 为 父类对象 进行初始化 定义父类对象 , 可以直接使用 子类对象 进行初始化操作 ; // II....// 将指向子类对象的指针传给接收父类指针的函数 // 也是可以的 fun_pointer(&child); // 接收父类引用 , 此处传入子类引用 fun_reference...// 将指向子类对象的指针传给接收父类指针的函数 // 也是可以的 fun_pointer(p_parent); // 接收父类引用参数 fun_reference(*

    30920

    struct 指向结构的指针,typedef 关键字,C++ 中的运算符重载,虚函数和纯虚函数,C++ 接口,#和##运算,c++线程

    指向结构的指针 指针的优点 a.为函数提供修改调用变元的灵活手段; b.支持C 动态分配子程序 c.可以改善某些子程序的效率 >>在数据传递时,如果数据块较大(比如说数据缓冲区或比较大的结构)...d.为动态数据结构(如二叉树、链表)提供支持 您可以定义指向结构的指针,方式与定义指向其他类型变量的指针相似,如下所示: struct Books *struct_pointer; 现在,您可以在上述定义的指针变量中存储结构变量的地址...为了查找结构变量的地址,请把 & 运算符放在结构名称的前面,如下所示: struct_pointer = &Book1; 为了使用指向该结构的指针访问结构的成员,您必须使用 -> 运算符,如下所示:...C++ 中的运算符重载 您可以重定义或重载大部分 C++ 内置的运算符。这样,您就能使用自定义类型的运算符。...下面是关于参数的说明: 参数 描述 thread 指向线程标识符指针。 attr 一个不透明的属性对象,可以被用来设置线程属性。您可以指定线程属性对象,也可以使用默认值 NULL。

    3900

    【C++】泛型编程 ⑧ ( 类模板继承语法 | 普通类 继承 类模板语法 | 类模板 继承 类模板语法 | 继承类模板必须指定具体的类型参数列表 | 继承 类模板 必须重写构造函数 )

    一、普通类 继承 类模板语法 1、普通类 继承 类模板语法 类模板 作为父类 , 子类 继承 类模板 父类 , 需要 指定 具体的类型参数列表 ; 需要 重写 构造函数 , 其中必须调用 类模板 具体类...的 子类 : // 类模板 继承时 , 需要具体化 类模板 // 也就是 指定 类模板 的 类型参数列表 , 将 泛型类型 固定下来 // C++ 编译器 只有知道了具体类型 , 才能知道 父类占用内存大小..., 调用 类模板 具体类 的构造函数 , 如果 子类 继承 类模板父类 , 如果 子类没有实现 构造函数 , // 类模板 继承时 , 需要具体化 类模板 // 也就是 指定 类模板 的 类型参数列表...继承时 , 需要具体化 类模板 // 也就是 指定 类模板 的 类型参数列表 , 将 泛型类型 固定下来 // C++ 编译器 只有知道了具体类型 , 才能知道 父类占用内存大小 // 才能正确分配内存...继承时 , 需要具体化 类模板 // 也就是 指定 类模板 的 类型参数列表 , 将 泛型类型 固定下来 // C++ 编译器 只有知道了具体类型 , 才能知道 父类占用内存大小 // 才能正确分配内存

    1.1K31

    【C++】构造函数初始化列表 ② ( 构造函数 为 初始化列表 传递参数 | 类嵌套情况下 的 构造函数 析构函数 执行顺序 )

    一、构造函数 为 初始化列表 传递参数 1、构造函数参数传递 构造函数 初始化列表 还可以使用 构造函数 中的参数 ; 借助 构造函数 中的参数列表 , 可以为 初始化列表 传递参数 ; 在下面的代码中...构造函数 向 初始化列表 的 参数传递 机制 ; 代码示例 : #include "iostream" using namespace std; class A { public: // 带参构造函数.../ 析构函数 执行顺序 ---- 1、构造函数 / 析构函数 执行顺序 类 B 中 定义了 A 类型 的 成员变量 ; A 类型对象 是 被组合对象 ; 构造函数执行顺序 : 在 初始化 B 类型 实例对象时..., 先执行 被组合对象 A 的构造函数 , 如果 被组合对象 有多个 , 则 按照 成员变量 的定义顺序 进行初始化 ; 注意 : 此处 不是按照 初始化列表 的顺序 进行初始化 ; 析构函数执行顺序...执行 B 的析构函数 执行 A 的析构函数

    26130
    领券