作者shihyu (shihyu)
看板C_and_CPP
标题[问题] std::shared_ptr std::vector
时间Thu Sep 28 22:40:26 2017
开发平台(Platform): (Ex: Win10, Linux, ...)
Linux
编译器(Ex: GCC, clang, VC++...)+目标环境(跟开发平台不同的话需列出)
g++
#include<iostream>
#include<vector>
#include <memory>
using namespace std;
int main()
{
// M□NM□N matrix (assuming int type elements) initialized with all
values as KK
const int N = 2;
const int M = 4;
const int K = 99;
std::vector<std::vector<int>>* p = new std::vector<std::vector<int>>(M,
std::vector<int>(N, K));
cout << p[0].size() << endl;
cout << p[0][0].size() << endl;
cout << p->at(0)[0] << endl;
delete p;
// cout << p->at(0)[0] << endl;
return 0;
}
我不想用delete 手动回收new 记忆体! 想使用shared_ptr
请问要怎麽把vector 指标用shared_ptr 封装一起自动回收?
shared_ptr<std::vector<std::vector<int> > > p1(new
std::vector<std::vector<int>>(M, std::vector<int>(N, 0)));
我这样包装对嘛? 有办法验证记忆体有回收掉?
谢谢
--
※ 发信站: 批踢踢实业坊(ptt.cc), 来自: 175.182.108.242
※ 文章网址: https://webptt.com/cn.aspx?n=bbs/C_and_CPP/M.1506609628.A.FD2.html
※ 编辑: shihyu (175.182.108.242), 09/28/2017 22:45:57
1F:推 james732: 要不要顺便学习用auto XD 09/28 22:47
2F:推 steve1012: 为啥不宣告物件就好? 09/28 23:07
3F:→ shihyu: 请问宣告物件是怎样? 对C++ 不熟XD 09/28 23:11
4F:推 steve1012: 赶着出门 让其他人回你 xD 09/28 23:19
5F:→ shihyu: OK! 可以先请问一下问题就是 shared_ptr 怎麽取得里面 09/28 23:39
6F:→ shihyu: 封装的vector 的row and col size 09/28 23:39
8F:→ shihyu: p1[0].size() & p1[0][0].size() 编译会错误 09/28 23:40
9F:推 steve1012: 你要的是 *p1.size()吧 09/29 00:02
10F:→ steve1012: vector 跟阵列是不一样的 你是不是搞混了 09/29 00:02
11F:→ steve1012: 你可以 (*p1)[0] 09/29 00:03
12F:→ steve1012: 不过你也可以 stdvector<int> newVec(3,1)之类 09/29 00:04
13F:→ steve1012: 这是宣告物件 09/29 00:04
14F:→ shihyu: (*p1)[0] 会编译失败...我主要想知道 shared_ptr 包起来 09/29 00:12
15F:→ shihyu: 怎麽取得里面vector col 大小 09/29 00:13
16F:→ shihyu: cout << (*p1)[0].size() << endl; // 这样可以取得col 09/29 00:32
17F:→ shihyu: steve1012 用shared_ptr 包物件从建构跟解构去验证回收? 09/29 01:02
18F:推 dannypsnl: sp->at(0).at(0)不要用[ ]运算子 09/29 01:46
19F:→ dannypsnl: 欸不对阿,我用运算子也行 09/29 01:49
20F:推 steve1012: 刚在忙 不过 lph大回你了你有问题再推个文吧 09/29 03:44
21F:→ Killercat: 你可能要先搞清楚shared_ptr的原理... 09/29 06:23
22F:→ Killercat: shared_ptr的自动回收不是靠GC机制 是靠物件的scope 09/29 06:23
23F:→ Killercat: 来判断reference count然後在rc=0的时候自爆的 09/29 06:24