我一直在编写自定义std::streambuf作为日志系统的一部分。但是,我遇到了流输出的第一段格式不正确的问题。这是一个不使用任何自定义streambuf或ostream类的简化测试用例:#includeintmain(){std::streambuf*coutbuf=std::cout.rdbuf();std::ostream(coutbuf)使用g++编译:$g++--versiong++(Ubuntu4.4.1-4ubuntu8)4.4.1$g++-ofailreduced-case.cpp$./fail0x400c80:writingtocoutusingaseparateo
我在openCV源代码中偶然发现了这段代码(cxoperations.hpp,第1134行,在Vector类的定义中):Vector(constVector&d,constRange&r){if(r==Range::all())r=Range(0,d.size());//somemorestuff...}请注意,Vector类没有名为r的数据成员(实际上,标识符r仅出现在整个类定义,作为另一个方法中的参数)。很显然,那是对const引用的赋值。我试图重现一个最小的例子:#includeclassFoo{public:int_a;Foo(inta):_a(a){}};intmain(){
我有一个自定义类,我希望它的行为像一个内置类型。但是我注意到您可以在不提供初始值的情况下初始化该类的常量变量。我的类当前有一个空的默认构造函数。这是int和我的类foo的比较:inta;//Validinta=1;//Validconstinta=1;//Validconstinta;//Errorfooa;//Validfooa=1;//Validconstfooa=1;//Validconstfooa;//Shouldcauseanerror,butitcompiles如你所见,我需要阻止constfooa;来自编译。C++专家有什么想法吗? 最佳答案
当我尝试使用boost编译我的服务器时,我遇到了很多错误。在这里,这是我的生成文件:NAME=serveurSRCS=Serveur/main.cpp\Serveur/Client.cpp\Serveur/Commande.cpp\Serveur/My_exception.cpp\Serveur/Network.cpp\Serveur/Server.cpp#####################################################OBJS=$(SRCS:.cpp=.o)CC=g++RM=rm-fCFLAGS=-g-W-Wall-WerrorINCL=./S
我是C++的新手,不明白为什么这段代码运行良好:stringGetString(stringpromt){cout像“bla”这样的字符串文字是constchar*类型。至少autoi="bla";表示i的类型为“constchar*”。为什么可以将它传递给GetString-Function,因为该函数需要一个字符串而不是constchar*? 最佳答案 std::string有一个convertingconstructor它采用charconst*并使用指针指向的空终止字符串初始化字符串。此构造函数不是显式,因此可用于隐式转换。
我正在阅读C++Primer,第5版,第1页。71他们首先给出了这个代码示例:constintci=0,&cj=ci;decltype(ci)x=0;decltype(cj)y=x;decltype(cj)z;//error然后他们说:Itisworthnotingthatdecltypeistheonlycontextinwhichavariabledefinedasareferenceisnottreatedasasynonymfortheobjecttowhichitrefers.这是什么意思?我不明白。y指的是x。那么有什么收获呢? 最佳答案
C是否像C++一样支持通过const引用传递?如果不是,是否有其他方法可以使按值传递更有效?我认为仅仅因为效率更高就传递对函数的引用是没有意义的。 最佳答案 C不支持引用或通过引用传递。您应该改用指针并按地址传递。按值传递对于原始类型是有效的,但对于结构来说是浅拷贝。在C++中,通过引用传递对象以提高效率非常有意义。当定义复制构造函数时,它可以节省大量的构造函数/析构函数的复制和调用。对于大型数据对象(例如std::list),按值传递是不切实际的,因为传递时会复制列表。在这里你绝对应该通过引用传递。
我知道当您想更改原始变量的值时,您会通过引用传递给C++中的函数。但是当您希望程序更高效并且不想更改传递给函数的变量中的任何内容时,您也可以通过引用传递,只需将其设为常量即可。我的问题是,为什么不总是让你的函数接受通过const引用传递的变量,如果它比仅仅传递变量并让编译器在函数范围内创建一个新变量更有效的话?要扩展这个问题,函数需要复制通过参数传递的变量的情况是什么? 最佳答案 当参数按值传递时,它是可修改的并且可以省略复制它。例如,实现赋值运算符的规范方式如下所示:T&T::operator=(Tvalue){value.swa
这个问题在这里已经有了答案:strcmporstring::compare?(6个答案)关闭8年前。提前为问题的基本性质道歉。我正在尝试使用strcmp函数来测试两个字符串的匹配字符。我将问题简化为下面的简单代码:#include#includeusingnamespacestd;voidcompareStrings(string,string);intmain(){stringstring1="testString",string2="testString";compareStrings(string1,string2);return0;}voidcompareStrings(str
我正在尝试创建一个类来抽象libuv网络功能的一些基本行为。#defineTCP_BACKLOG256class_tcp{uv_tcp_t*tcp=NULL;public:~_tcp(){deletetcp;}voidlisten_uv_listen_uv_connection_cb(uv_stream_t*stream,intstatus){printf("NEWCONNECTION\n");}voidlisten(constchar*host,intport){tcp=newuv_tcp_t();uv_tcp_init(uv_default_loop(),tcp);sockaddr