草庐IT

-std=gnu99

全部标签

c++ - 为什么在声明 std::set 时需要重复排序子例程?

在我的C++程序中,我试图按值而不是键对我的map进行排序。来自thisquestion,很明显,这样做的方法是创建一个集合,其元素是成对的,并且由我自己的小于函数排序。这是我尝试执行此操作的一些示例代码:#include#include#include#includeusingnamespacestd;boolcompareCounts(constpair&lhs,constpair&rhs);intmain(intargc,char*argv[]){mapcounter={{"A",1},{"B",2},{"C",3}};set,decltype(compareCounts)*>s

c++ - std::string 和 UTF-8 编码的 unicode

如果我理解的很好,可以同时使用string和wstring来存储UTF-8文本。对于char,ASCII字符占用一个字节,一些中文字符占用3或4个字节,等等。这意味着str[3]不一定指向第4个字符。与wchar_t相同,但每个字符使用的最小字节数始终为2(而不是char的1),以及3或4字节宽的字符将占用2个wchar_t。对吗?那么,如果我想对这样一个奇怪编码的字符串使用string::find_first_of()或string::compare()等怎么办?它会工作吗?字符串类是否处理字符具有可变大小的事实?或者我应该只将它们用作虚拟的无特征字节数组,在这种情况下我宁愿选择wc

c++ - 为什么 std 智能指针类型析构函数不继承指向对象的 noexcept dtor 状态

在C++11中,我的理解是默认情况下析构函数是隐式的noexcept(true),除了:如果我有一个类C有一个显式标记为noexcept(false)的析构函数(大概是因为它出于某种奇怪的原因抛出,我知道你不应该,为什么)然后是派生自C的任何类的析构函数或包含C类型的成员也变成noexcept(false).但是,一个包含std::shared_ptr的类显然不会自动将其析构函数切换为noexcept(false),包含std::weak_ptr也是如此,std::unique_ptr等这是一个完整的例子:#include#includestructNormal{~Normal(){}

c++ - std::numeric_limits<T>::digits 应该代表什么?

我正在编写一个类似整数的类,它代表一个位于某个范围内的值。例如,bounded::integer的值位于[0,10]范围内的某处。对于这个类,我定义了radix成为2.digits的值应该是多少?为bounded::integer?那bounded::integer呢?? 最佳答案 在进一步阅读标准并思考这个问题后,我相信我有最好的答案,但我不确定。首先是digits的定义,取自最新的C++14标准草案,N3797,§18.3.2.4:staticconstexprintdigits;8Numberofradixdigitsthat

c++ - 用于初始化 2D std::array 成员的初始化列表

如何通过初始化列表初始化嵌套的(2D)std::array?templateclassBlock{std::array,H>block;public:templateBlock(E&&...e):block{{std::forward(e)...}}{}};类Block应该能够初始化block成员,如下所示:Blockb{{{1,2,3},{4,5,6}}};注意:我们可以在C++11中直接初始化std::array:std::array,2>b{{{1,2,3},{4,5,6}}};我正在使用gcc-4.9.0 最佳答案 当涉及到

C++ - 将对象添加到 std::vector,在循环中实例化

我是专家级别的Java程序员,正在尝试将我的知识移植到C++。这不是家庭作业,只是我试图学习C++等价物的概念。我想做的是使用循环“生成”自定义类型的对象列表。这就是我在Java中的做法:publicclassTestClass{privateArrayList_exampleObjects;privateint_numObjects=10;publicvoidpopulateList(){_exampleObjects=newArrayList();for(inti=0;isuper简单的东西。创建一个列表,遍历任意循环并向其中添加对象。然后,循环遍历这些对象并将它们用于任何目的。测

c++ - std::string _M_leak_hard 和性能问题

在分析C++应用程序时,我注意到以下代码:std::strings;inti;dict[s[i]]++;产生(内联)std::string::_M_leak_hard的调用,链接到std::string::_M_mutate等(gcc-4.7.3),并通过大量CPU指令比较字符串的内部状态,在应该是const上下文的地方并优化为简单的内存读取。我是不是做错了什么?std::string特定于实现的细节链很容易消耗50%的CPU时间。 最佳答案 您正在查看的代码确实是std::string的gcc实现中的unsharing。至于为什么

c++ - 编译器是否可以在仅引用一次时隐式 std::move 参数?

假设我有一个带有setter的简单类:classMyClass{public:voidsetName(std::stringname){_name=std::move(name);}private:std::string_name;};我在这里使用std::move,但是如果我忽略它而只写_name=name,编译器是否可以隐式movename参数,因为它没有在setter的其他任何地方使用?它几乎可以被视为赋值表达式中的右值,因为它在其他任何地方都没有被名称引用。编译器能做到吗?现有的编译器会这样做吗? 最佳答案 在什么之上添加N

c++ - std::vector::erase(item) 需要为项目定义赋值运算符?

我有一个类C没有定义operator=.我正在尝试使用这样的vector:std::vector>vec;.现在,我的问题是完成后我无法删除这对。编译器提示缺少operator=对于C.我不能有一个没有这个运算符的类的vector吗?我该如何解决这个问题?我无法将作业添加到C.这是我得到的错误:errorC2582:'operator='functionisunavailablein'C'C:\...\include\utility1961my-lib这是我的代码:voidRemove(constC&c){autoi=cs_.begin();while(i!=cs_.end()){if

c++ - std::random_shuffle 产生相同的结果,即使 srand(time(0)) 被调用一次

在一个函数中,我想生成一个范围内的数字列表:(该函数只会在程序执行时被调用一次。)voidDataSet::finalize(doubletrainPercent,boolgenValidData){srand(time(0));printf("%d\n",rand());//indices={0,1,2,3,4,...,m_train.size()-1}vectorindices(m_train.size());for(size_ti=0;i结果是这样的:850577673246239710241201288231237几秒钟后:856981140246239710241201288