//初始化申请到的4个字节为0memset(ptr1,0,4);if(ptr1!=NULL){//如果指针变量不为NULLfree(ptr1);ptr1=NULL;//让指针指向NULL地址}//我们故意去解这个指针的引用 这时候就会发生异常报错,因为对空指针解引用了printf("%d\n",*ptr1); 有关C语言中动态内存申请,我们一般需要注意以上的这些点,而C++是...
在该示例中,我们通过std::make_shared函数创建了两个动态分配的字符串,并将其放入strings容器中。使用shared_ptr可以确保在不再需要字符串时,动态内存会被自动释放。 总结 通过传递指针和引用,我们可以直接操作和修改原始数据,避免了进行完整的复制过程。而使用vector<shared_ptr<string>>可以方便地管理动态分配的字符...
在pro内部计数器是2inti = *p;//计数器为1cout<< i <<endl;int* bad = newint(11);//pro(bad);//编译错误pro(shared_ptr<int>(bad));//合法,但出了pro,bad所指向的内存会被释放intj = *bad;//解指针bad就会产生难以预料的结果
shared_ptr<int> sp(newint(10));//一个指向整数的shared_ptrassert(sp.unique());//现在shared_ptr是指针的唯一持有者shared_ptr<int> sp2 = sp;//第二个shared_ptr,拷贝构造函数assert(sp == sp2 && sp.use_count() ==2);//两个shared_ptr相等,指向同一个对象,引用计数为2*sp2 =100;//使用...
1、shared_ptr智能指针的创建 shared_ptr 类模板中,提供了多种实用的构造函数,这里给读者列举了几个常用的构造函数(以构建指向 int 类型数据的智能指针为例)。 1) 通过如下 2 种方式,可以构造出 shared_ptr 类型的空智能指针: 注意,空的 shared_ptr 指针,其初始引用计数为 0,而不是 1。
参考:https://zh.cppreference.com/w/cpp/memory/shared_ptr std::shared_ptr是通过指针保持对象共享所有权的智能指针。多个shared_ptr对象可占有同一对象。下列情况之一出现时销毁对象并解分配其内存: 最后剩下的占有对象的shared_ptr被销毁; 最后剩下的占有对象的shared_ptr被通过operator=或reset()赋值为另一指针...
weak_ptr引入可以解决shared_ptr交叉引用时无法释放资源的问题。 示例代码: #include<iostream>#include<memory>usingnamespacestd;classB;classA{public:A(){cout <<"A constructor ... "<< endl;} ~A(){cout <<"A destructor ..."<< endl;} ...
std::shared_ptr<TestClass> ptr_test = std::shared_ptr<TestClass>(pTest); //普通指针转shared_ptr //此处 pTest 不用手动释放 因为 ptr_test 的引用计数为1 std::shared_ptr<TestClass> ptr_test2 = std::make_shared<TestClass>();
shared_ptr<int>p4(newint(1024)); //shared_ptr<int> p5 = new int(1024); // wrong, no implicit constructor cout<<*p4<<endl; 但是,不能将一个new表达式返回的指针赋值给shared_ptr。 另外,特别需要注意的是,不要混用new和shared_ptr!
shared_ptr允许多个指针指向同一个对象;unique_ptr则“独占”所指向的对象。标准库还定义了一个名为weak_ptr的伴随类,它是一种弱引用,指向shared_ptr所管理的对象。这三种类型都定义在memory头文件中。 make_shared的标准库函数在动态内存中分配一个对象并初始化它,返回指向此对象的shared_ptr。与智能指针一样,ma...