草庐IT

弱引用

全部标签

C++ 流引用作为类成员

我有一个类是这样的:#includeclassA{public:A(std::istream&is):_is(is){}voidsetInputSource(std::istream&is){_is=is;}A&operator>>(int&x){_is>>x;return*this;}private:std::istream&_is;};我想要_is成员(member)仅供引用。我的意思是,它必须“指向”外部std::istream我不想要setInputSource()复制作为参数传递的流的方法。问题是程序无法编译,因为我提到的那个方法试图访问operator=类(class)st

C++ 无法使用通用引用 move unique_ptr

考虑这段代码:templateTmov(T&&t){returnstd::move(t);}intmain(){std::unique_ptra=std::unique_ptr(newint());std::unique_ptrb=mov(a);}mov函数应该简单地接受一个通用引用并按值返回它,但是通过move而不是复制它。因此,调用此方法时不应涉及复制。因此,使用只能move的unique_ptr调用这样的函数应该没问题。但是,此代码无法编译:我收到错误:test.cpp:24:34:error:useofdeletedfunction‘std::unique_ptr::uniqu

c++ - 如何检查从哪里引用函数

在裸机C/C++项目中,我使用gcc-arm-embedded(目前最新的4.9-2015-q2)。出于某些原因,我必须避免使用某些函数,例如一些stdio等(不想使用重定向或半主机)。此外,我将FreeRtos与heap_4.c一起使用,例如malloc()直接重定向到pvPortMalloc()像这样:void*malloc(size_ts){returnpvPortMalloc(s);}因此,我不想在我的二进制文件中包含工具链堆管理代码的任何部分。现在,在某些情况下,我团队的开发人员意味着使用例如printf()间接引用_malloc_r()(以及更多)并且实际上很难找出它的引用

c++ - 为什么有的引用类型的变量可以绑定(bind)右值,有的不能?

#includeusingnamespacestd;intmain(){//int&a=3;我不明白为什么编译器不会引发编译错误。由于auto“强制”c成为对常量int的引用,并且引用被引用到左值,这是如何工作的? 最佳答案 如果没有const,这确实无法工作——您会遇到编译错误。但是const在那里,即您不会修改c引用的内容。对于这种情况,标准中有额外的措辞,临时值c正在引用(1+2的结果)将其生命周期延长到引用生命周期的末尾。这与auto完全无关。const在这里产生了不同。 关于c

c++ - 将 unique_ptr 的 vector 传递给函数,const 引用

我通常会像这样传递一个包含原始指针的vector:someFunc(conststd::vector&classList){..}我想知道你是否可以像这样对unique_ptr做同样的事情:someFunc(conststd::vector>&classList){..}?它的意思是一样的吗?即只读。 最佳答案 是的,你可以。不,这不是同一件事:std::unique_ptr表示指针拥有的资源。通用原始指针可以具有许多其他语义。关于const的正确性,使用迭代器或operator[]访问vector的元素将产生对std::uniqu

c++ - 引用限定符和删除的成员方法

考虑以下代码:#includestructS{voidf(int)=delete;voidf(int)&&{}};intmain(){}它不会编译说成员方法不能重载,当然这是有道理的。另一方面,编译以下代码:#includestructS{voidf(int)&=delete;voidf(int)&&{}};intmain(){Ss;//s.f(42);这是合法的代码吗?难道不能在同一个类中定义两个完全不同的接口(interface),前者与左值一起使用,后者与右值一起使用吗?除了没有多大意义,但它确实让我很受伤。一个被删除的函数不应该作为一个整体被删除,而不是只有当你是左值时才被删除

c++ - 在递归中使用按引用传递

intf(int&x,intc){c=c-1;if(c==0)return1;x=x+1;returnf(x,c)*x;}intx=5;cout在上面的示例中,可供选择的四个可能答案是:3024656155440161051函数f(int&x,intc)在第一次调用之后被调用四次,然后到达返回结果6561的基本情况。我猜是3024但我错了。即使通过引用传递的x变量在每次调用f(int&x,intc)时递增并取值6->7->8->9分别这个递归的最终结果等于9^4。所以我的问题是:变量x是通过引用传递的,当到达基本情况时等于9。这是否意味着递归的所有阶段都将具有变量x的这个值,即使它们在

C++11:函数模板:通过引用传递参数

有一种模板函数通过引用传递参数+回调函数,但是如果参数通过引用传递给回调函数则编译器会抛出错误:nomatchingfunctionforcalltofunc(int&,void(&)(int&)).怎么了?templateusingfunc_t=void(T);templatevoidfunc(T&arg,func_tcallback){callback(arg);}voidfunc1(intarg){}voidfunc2(int&arg){}// 最佳答案 扣除T在第二次调用中失败,因为T出现在两个推断的上下文中,这两个上下文推

c++ - 单击旁边的按钮时如何引用动态创建的标签[Qt]

每次按下“添加客户端”按钮-一个减号按钮、客户端名称、一个客户端计数器和一个加号按钮被添加到gridLayout的水平线上。我想在按下加号/减号按钮时更新计数(QLabel)。这是我的代码:#include"widget.h"#include"ui_widget.h"#include#include#includeintrow=0;Widget::Widget(QWidget*parent):QWidget(parent),ui(newUi::Widget){ui->setupUi(this);}Widget::~Widget(){deleteui;}voidWidget::on_pu

c++ - 函数重载优先级(引用)

voidfunc(constint&){std::cout由于const左值引用能够接受各种数据(const和非lval,const和非右值),我想知道上面的代码将打印“rvref”的保证是什么。它是标准化的还是依赖于编译器的? 最佳答案 我之前的解释是不正确的-作为T.C.mentionedinthecomments,两个重载具有相同的隐式转换序列,并且消除歧义作为标准中定义的特殊决胜局发生。§13.3.3.1.4[over.ics.ref],par.1Whenaparameterofreferencetypebindsdirec