LLDB:打印一个shared_ptr引用的向量
LLDB: printing a vector referenced by a shared_ptr
在我的代码中有这样的东西:
shared_ptr<vector<unsigned int>> f =
make_shared<vector<unsigned int>>();
我如何才能漂亮地打印矢量,因为我只能使用访问shared_ptr对象
frame variable f
和
frame variable f.__ptr_->size()
call to a function 'std::__1::vector<unsigned long, std::__1::allocator<unsigned long> >::size() const' that is not present in the target
得到这个错误吗?
给定以下代码片段:
#include <vector>
#include <memory>
using namespace std;
int main()
{
shared_ptr<vector<unsigned int> > f =
make_shared<vector<unsigned int> >();
f->push_back(1);
f->push_back(1);
f->push_back(1);
return 0;
}
LLDB只是为我工作:
(lldb) fr var
(std::__1::shared_ptr<std::__1::vector<unsigned int, std::__1::allocator<unsigned int> > >) f = 0x00000001001038c8 size=3 (strong=1 weak=1) {
__ptr_ = 0x00000001001038c8 size=3
}
更好的是,如果我扩展__ptr_:
(lldb) fr var --ptr-depth=2
(std::__1::shared_ptr<std::__1::vector<unsigned int, std::__1::allocator<unsigned int> > >) f = 0x00000001001038c8 size=3 (strong=1 weak=1) { __ptr_ = 0x00000001001038c8 size=3 {
[0] = 1
[1] = 1
[2] = 1 } }
相关文章:
- CLANG 编译器 说:变量"PTR"可能未初始化
- 在以唯一ptr为值的C++映射中,动态内存何时会被销毁
- 将 ptr 传递给 ptr 到 A 作为参数传递给 A 的函数是不好的做法吗?
- 为共享 ptr 向量实现复制 c'tor?
- 字符和整数中 **(ptr+1) 的值差异
- C++:在不中断共享的情况下通过引用传递共享 PTR?
- 如何将派生类从基 ptr 分配给 nlohmann::json
- 引用 std::shared:ptr 以避免引用计数
- 为什么我不能在不进行任何转换的情况下将浮点数放入任何类型的 ptr 中?
- 在调用函数时,ptr** 和 ptr*& 之间是否有区别,或者首选C++?
- 另一种类型的智能ptr,比如具有弱refs的unique_ptr
- 尝试打印出 *ptr++ 的值,以了解它是如何工作的
- 如何控制共享 ptr 引用计数?
- dopen():不以 root 身份运行时"failed to map segment from shared object"
- C++中的指针否定 (!ptr == NULL)
- 从const ptr*转换为ptr*时出现问题
- 无法使用 libtool 将 -shared 参数传递给 g++
- boost::shared_ptr和std::shared-ptr的同居
- 我可以用std::shared_ptr而不是boost::shared-ptr构建boost库吗
- shared-ptr-C++shared_ptr与unique_ptr用于资源管理