jjzjj

smart-pointers

全部标签

native smart contracts, a easy forgotten thing.

"内置的智能合约"是指在区块链网络中预先存在的智能合约。这些合约通常由区块链的开发者编写,并在区块链网络创建时就已经部署。这些合约的功能通常包括处理基本的交易和账户管理等核心功能。以太坊网络就有一种内置的智能合约,叫做ERC-20合约1。ERC-20是一种代币标准,定义了一套接口,任何遵循这个标准的智能合约都可以在以太坊网络上作为代币使用1。以下是一个ERC-20合约的简单示例1:pragmasolidity^0.8.7;contractERC20Basic{stringpublicconstantname="BasicToken";stringpublicconstantsymbol="BA

c++ - C/C++ 指针,ptr+1 = ptr +1 byte 还是 ptr+1*sizeof(pointer_type)?

有any_type*ptr=(any_type*)malloc(sizeof(any_type)*size);my_ptr=ptr+1;memcpy(dst,my_ptr,sizeof(any_type));my_ptr会指向ptr之后的1个字节,还是指向ptr之后的sizeof(any_type)字节?对齐选项如何影响答案?有符号/无符号类型是否不同? 最佳答案 指针运算是在指针的静态类型[*]的大小上进行的,所以它会有效地添加sizeof*ptr。成员的对齐方式将作为类型的对齐方式(对象末尾的填充)考虑到对象的大小。struct

c++ - 在 C++ 中,表达式 "*pointer++"是如何工作的?

#includeusingnamespacestd;intmain(){intvalue=1,*pointer;pointer=&value;cout为什么++运算符不增加value? 最佳答案 Post-increment(++)hashigherprecedencethandereference(*).这意味着++绑定(bind)到pointer而不是*pointer。参见CFAQ4.3以及其中的引用资料。 关于c++-在C++中,表达式"*pointer++"是如何工作的?,我们在

c++ - 我必须在 C++ 析构函数中收集什么垃圾

我正在编写一个C++析构函数(我希望这是正确的术语;我是C++的新手)并且我不确定我究竟需要什么来进行垃圾收集。假设我有2个指针作为实例变量,我需要对它们进行垃圾回收吗?如果我有一个对象作为实例变量呢?还是指向对象的指针?对于究竟需要删除什么以及自动清理什么,我只是有点模糊。谢谢 最佳答案 一般的经验法则是...如果您调用new,请调用delete。如果您调用了new[],请调用delete[]。如果您在类之外访问这些指针并有效地共享它们,您需要小心“拥有”对象delete正在使用的共享对象。垃圾收集这个词不太合适。您想要销毁对象并

c++ - 如何摆脱 - 来自 NULL 的 "warning: converting to non-pointer type ' 字符”?

我有这段代码:intmyFunc(std::string&value){charbuffer[fileSize];....buffer[bytesRead]=NULL;value=buffer;return0;}行-buffer[bytes]=NULL给我一个警告:convertingtonon-pointertype'char'fromNULL。我如何摆脱这个警告? 最佳答案 不要使用NULL?它一般是为指针保留的,你没有指针,只有一个简单的char。只需使用\0(空终止符)或简单的0。

c++ - 将指针容器转换为智能指针?

是否有一种简洁、通用的方法来转换常规/哑指针的std容器(例如vector):vector例如,boost::shared_ptr?:vector>我想我可以使用vector的范围构造函数来完成它:vectorvec_a;...vector>vec_b(vec_a.begin(),vec_a.end());但是拒绝编译(VisualStudio2008)。编辑:测试代码:voidtest(){vectorvec_a;vector>vec_b(vec_a.begin(),vec_a.end());}编译错误:1>c:\ProgramFiles(x86)\MicrosoftVisualSt

c++ - shared_ptr 与指针共存

我有一个函数如下voida(shared_ptrval){...}有时候,我想传入一个堆分配的对象shared_ptrv(newX());a(v);其他时候,我想传入一个堆栈分配的对象classC{//doesn'tworkproperlyb/cwhentheshared_ptrdiesitwilltrytodeletex...C(){a(shared_ptr(&x));}Xx;};让函数接受智能指针,同时让智能指针引用堆栈分配对象的最佳方法是什么?或者我应该走Java路线并从堆中分配所有内容? 最佳答案 我只想让函数采用这样的模板

c++ - 在 C/C++ 中编写 "pointer to something"的好方法

在C/C++中是否有一种“好的”方式来编写“指向某物的指针”?我曾经写过voidfoo(char*str);但有时我发现它很不合逻辑,因为str的类型是“指向char的指针”,那么它应该更合乎逻辑将*附加到类型名称。写指针有规律吗?char*str;char*str;char*str;char*str; 最佳答案 没有严格的规则,但请记住*附加到变量,所以:char*str1,*str2;//str1andstr2arepointerschar*str1,str2;//str1isapointer,str2isachar有些人也喜欢

c++ - 将智能指针所有权转移到容器

我的数据结构通常通过std::unique_ptr管理,例如AST中的表达式。structBinExpr{std::unique_ptrleft;//Leftownstheexpressionstd::unique_ptrright;//Rightownstheexpression};在大多数情况下效果很好。但有时我没有固定数量的表达式可以拥有,例如在列表中structListExpr{std::vector>exprs;//Exprsownspointerswhicheachownanexpression};但我不喜欢通过vector中的智能指针这种额外的间接寻址,我认为它没有表达我

c++ - 如何正确地将 _bstr_t 重置为 `NULL`

在下面的代码片段中(循环的简化场景)_bstr_toriginal(OLESTR("MyString"));//ref-count=1_bstr_tanother;another=original;//ref-count=2//dosomethingwithanotheranother.Assign(NULL);//expected:ref-count=1,andanother=NULL//resetanothertoNULLbeforedoingotheroperations在another.Assign(NULL)之后我期望的是:SysFreeString()未被调用另一个设置为N