草庐IT

std-ranges

全部标签

c++ - 不同类型的 std::chrono::duration 的 std::min

考虑以下代码://durationsarefromstd::chronoautoa=get_duration_1();//milliseconds,willvaryinfutureversionsautob=get_duration_2();//seconds,willvaryinfutureversionsautoc=std::min(a,b);它无法编译,因为编译器无法实例化std::min的正确版本因为参数类型不同。当然,现在可以使用std::min明确指定类型.在此代码的future版本中,类型会有所不同。在不知道确切持续时间类型的情况下执行此操作的通用方法是什么?

c++ - C++17 std::basic_string_view 是否会使 C 字符串的使用无效?

C++17正在引入std::basic_string_view,它是非拥有字符串版本,其类仅存储指向字符串第一个元素的指针和字符串的大小。还有理由继续使用C字符串吗? 最佳答案 IstherestillareasontokeepusingCstrings?我认为可以公平地说,除了使用CAPI之外,从来没有有理由使用C字符串。在设计只需要字符的只读表示的函数或方法的接口(interface)时,您会更喜欢std::string_view。例如。搜索字符串、生成大写拷贝、打印它等等。在设计一个接受字符串拷贝的接口(interface)时

c++ - 在 ostream 上使用 std::endl 使我的文件成为二进制文件

我正在从事一个使用libzip的项目。我在c++14工作,我围绕libzip编写了一个小包装器,让我的生活更轻松。我有一个std::ostream对象围绕继承std::streambuf的自定义类构建。此streambuf使用libzip函数写入存档中的文件。一切正常,直到我使用std::endl。当我这样做时,输出文件被我所有的文本阅读器读取为二进制文件(仅写入字符串)。我的文本阅读器检测到它是二进制文件,因为在我使用std::endl的地方有一个NUL字节,任何包含NUL字节的文件都被视为二进制文件。所以我的问题是:这正常吗?我有办法使用std::endl吗?我的代码(已提取,因此

c++ - 指向 std::thread 的共享指针是一种不好的做法吗?

使用std::shared_ptr有意义吗?逻辑很简单:如果不需要线程,则删除它,如果需要新线程-重新分配它。有什么方法可以将这个概念与线程池进行比较吗?我确实知道我系统中线程的确切数量(我开发了图像处理算法,我想给“算法”类的每个子级一个单独的线程(也许让它私有(private),然后不需要shared_ptr),该算法将在何处运行,如果未提供图像,则将此私有(private)线程闲置。这是一个糟糕的概念吗? 最佳答案 您可能错过了事实std::thread析构函数不会终止线程。正如评论中已经提到的,ifdetachorjoinw

c++ - std::this_thread::sleep_for(2s) 中的 s 是什么?

我找到了std::this_thread::sleep_for可以处理时间单位s。std::this_thread::sleep_for(2s);但是我不知道2s中的s是什么。 最佳答案 Whatissinstd::this_thread::sleep_for(2s)?s是一个用户定义的文字使得2schrono::second类型的文字值.内置文字您可能熟悉integerliterals和floatingliterals;这些是内置后缀:+--------+---------+---------------+|Suffix|Exam

c++ - 通过将其分配给 const std::tuple<int, int>& 来延长 std::tuple<int&,int> 的生命周期

我使用的是std::tuple类并发现我会说的是相当意外的行为。考虑代码:#include#includeinti=20;std::tuplef(){returnstd::tuple(i,0);}intmain(){conststd::tuple&t=f();intj=++i;std::cout(t)这似乎编译并打印了20在所有主要编译器上。由于两种类型不同,此标准是否符合标准或未定义的行为?我知道可以通过将临时分配给constT&来延长它的生命周期。,但据我所知std::tuple与std::tuple的类型不同. 最佳答案 这是

c++ - delete[] 是否适用于通用数组?如果是这样,为什么在其上使用 std::vector::erase 会导致释放内存时出错

我曾尝试使用圆形数组,因此最终编写了一个CircularArray类,并附上了代码。它使用数组的通用指针。当我尝试使用std::vector创建此类圆形数组的列表时,我在尝试对其使用删除时遇到了问题。我不明白为什么会这样,因为我认为析构函数和复制构造函数正常工作得很好。有人可以帮忙吗?代码:CircularArray类templateclassCircularArray{//Classdenotedby'T'isexpectedtohaveafunctionalassignmentoperator,i.e.operator=(constT&ext){}inplaceprotected:

c++ - 从 std::array 等获取 size_type 的惯用方法

由thisquestion触发,我想出了以下代码(在我的回答中是boost::array,但同样适用于std::array):template::size_typesize>voidDataTransform(std::arraydata){}我对::size_type一点都不满意.我必须以一定的大小进行实例化,才能知道size_type.对于std::array我本可以使用size_t,那么一般情况呢?如果size_type怎么办不是size_t?或者更一般的(即不适用于std::array)如果size_type怎么办?不同的尺寸是不同的(愚蠢但可能)?我知道这个问题相当学术,有很

c++ - 比较 std::tr1::function<> 对象

我一直在尝试使用用于存储处理事件的函数的tr1函数模板在C++中实现类似C#的事件系统。我创建了一个vector,以便可以将多个监听器附加到此事件,即:vector>listenerList;我希望能够从列表中删除处理程序以停止监听器接收事件。那么,我如何才能在此列表中找到对应于给定监听器的条目?我可以测试列表中的“函数”对象是否引用特定函数吗?谢谢!编辑:在研究了boost::signal方法之后,它似乎可能像你们中的一些人所建议的那样使用token系统来实现。Here'ssomeinfoonthis.观察者在附加到事件时会保留一个“Connection”对象,并且此连接对象用于在需

c++ - 字符串比较。如何比较字符串与 std::wstring? WRT 结构体

我正在尝试比较两种格式,我认为它们在某种程度上是兼容的,因为它们通常都是字符串。我曾尝试使用字符串和std::wstring执行strcmp,而且我确信C++专家知道,这根本无法编译。是否可以比较这两种类型?这里有一个简单的转换吗? 最佳答案 您需要将char*字符串(ISOC术语中的“多字节”)转换为wchar_t*字符串(ISOC术语中的“宽字符”)。执行此操作的标准函数称为mbstowcs("多字节字符串转宽字符串")注意:正如史蒂夫在评论中指出的那样,这是一个C99函数,因此不符合ISOC++标准,但可能会作为扩展由C++实