草庐IT

Push-based

全部标签

c++ - push_back 新元素到 vector

我有这个vector:std::vectormy_vector;我想使用默认构造函数添加新项目。所以,我写:my_vector.push_back(my_class());有没有办法不直接提及类型就可以做到这一点?。例如:my_vector.push_back(auto());//imaginarycode 最佳答案 std::vector有一个名为emplace_back的成员函数它根据提供给函数的参数在vector中构造vector元素类型的新实例。所以如果my_class是默认可构造的,你可以这样做:my_vector.emp

arm push/pop/b/bl汇编指令

目录1.push指令2.pop指令3.b指令4.bl指令5.bx指令1.push指令功能描述:入栈armv7芯片手册:PushMultipleRegistersstoresmultipleregisterstothestack,storingtoconsecutivememorylocationsendingjustbelowtheaddressinSP,andupdatesSPtopointtothestartofthestoreddata.语法 要点:push支持同时将多个寄存器入栈,格式:{xx,xx},如:push{r0,r1,r2} 入栈顺序是先入栈序号低的寄存器到最低地址,比如pu

c++ - Noexcept 对派生类构造函数的 promise : can that be used without promising noexcept on base constructor?

假设我有一个类classC:publicB{public:C()noexcept;}noexcept说明符是否需要基类的相同promise?也就是说,当我考虑使用noexcept时,我是只看C::C()的行为还是我还需要考虑B::B()是否可能抛出异常?例如,如果B::B抛出异常,它会传播到C::C还是传播到请求新类实例的代码?--如果传播到C::C,如果基类不是noexceptforconstructor,那将是避免noexceptforconstructor的原因之一。 最佳答案 技术上†不要求将基类构造函数声明为noexcep

C++ deque 的迭代器在 push_front() 之后失效

刚才,我正在阅读Josuttis的STL书。据我所知——c++vector是一个可以重新分配的c数组。所以,我明白了,为什么在push_back()之后所有的迭代器和引用都会变得无效。但我的问题是关于std::deque。据我所知,它是大块数组(c数组的c数组)。所以push_front()在开头插入元素,如果没有空间,deque分配新block,并将元素放在已分配block的末尾。在中间的insert()之后,所有引用和迭代器都变得无效,我明白为什么——所有元素都被移动了。但我真的误解了短语“...在push_back()和push_front()之后所有引用都保持有效,但迭代器不有

带有 std::is_base_of 的派生类的 C++ 模板函数

我在为给定类型创建函数时遇到问题,如果它是从其他类型派生的,那么它会做某事,而对于所有其他情况,则做其他事情。我的代码:classBaseClass{};classDerivedClass:publicBaseClass{};templatevoidFunction(typenamestd::enable_if::value,T>::type&&arg){std::coutvoidFunction(T&&arg){std::cout对于DeriviedClass类和其他基于BaseClass的类,我想调用函数coutingProper,但是它couts不正确。有什么建议吗?

c++ - 是否存在将 push_back 替换为 emplace_back 不正确的情况?

我能否通过将std::vector::push_back替换为emplace_back并使用C++11编译器编译它来破坏有效的C++03程序?通过阅读emplace_back引用,我认为这不应该发生,但我承认我没有完全获得右值引用。 最佳答案 我构建了一个简短的示例,当push_back被替换为emplace_back时实际上无法编译:#includestructS{S(double){}private:explicitS(int){}};intmain(){std::vector().push_back(0);//OKstd::v

c++ - "Empty base optimization"用于 lambda 捕获 - 被标准禁止?为什么?

我最近遇到了一种情况,我最终得到了大量嵌套的lambda表达式到buildasynchronouscomputationchains。.templatestructnode:F{node(F&&f):F{std::move(f)}{}templateautothen(FThen&&f_then){return::node{[p=std::move(*this),t=std::move(f_then)](){}};}};intmain(){autof=node{[]{}}.then([]{}).then([]{});returnsizeof(f);}我在lambda中捕获的所有对象都是空

在HTTP请求中安全传输base64编码的字符串

前言base64是一种常见的的编码格式,它可以把二进制数据编码成一个由大小写英文字母(a-zA-Z)、阿拉伯数字(0-9),以及三个特殊字符+、/、=组成的字符串。问题但是在URL传输中,+、/、=这三个特殊字符是保留字符(或者叫不安全字符),如果将编码后的base64字符串直接用于URL传输,可能会有意外发生。例如,假设base64编码后的字符串是x+y,前端访问https://www.mysite.com?name=x+y,后端接收到的name参数的值却是xy,+号不见了,变成了空格。解决方案一、在传递参数前,先对其进行URL编码只要我们在传递base64字符串之前对其进行URL编码,这些

java.lang.IllegalAccessError: class org.jetbrains.kotlin.kapt3.base.KaptContext cannot access class

Task:app:kaptGenerateStubsDebugKotlinFAILEDe:java.lang.IllegalAccessError:classorg.jetbrains.kotlin.kapt3.base.KaptContext(inunnamedmodule@0x4d1ecff7)cannotaccessclasscom.sun.tools.javac.util.Context(inmodulejdk.compiler)becausemodulejdk.compilerdoesnotexportcom.sun.tools.javac.utiltounnamedmodule@0

c++ - `Base *b = new Base;` 与 `Base *b = new Base();` 没有定义我自己的构造函数

如果我不定义自己的构造函数,Base*b=newBase;与Base*b=newBase();之间有什么区别吗? 最佳答案 初始化是标准中要遵循的一种PITA...然而,这两个已经存在的答案在他们遗漏的内容上是不正确的,这使他们确认没有区别。在没有用户定义的构造函数的类中调用newT和newT()之间存在巨大差异。在第一种情况下,对象将被默认初始化,而在第二种情况下,它将被“值初始化*”。如果对象包含任何POD子对象,那么第一个将使POD子对象保持未初始化状态,而第二个会将每个子元素设置为0。structtest{intx;std: