草庐IT

find_or_initialize_by

全部标签

c++ - 性能 std::strstr 与 std::string::find

这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:C++string::findcomplexity最近我注意到函数std::string::find比函数std::strstr慢一个数量级-在我的GCC4.7环境中在Linux上。性能差异取决于字符串的长度和硬件架构。差异的原因似乎很简单:std::string::find基本上在循环中调用std::memcmp-具有时间复杂度O(m*n)。相比之下,std::strstr针对硬件架构进行了高度优化(例如使用SSE指令)并使用更复杂的字符串匹配算法(显然是Knuth-Morris-Pratt)。我也很惊讶没

C++11 initializer_list 构造函数标记为 "explicit"

我能否将explicit与init-list构造函数一起使用,以确保像{a}这样的表达式不会导致意外的隐式转换?还有一个想法:应该我担心吗?编写{a}比简单地编写a不太可能出错,但另一方面,从代码中我们可能仍然不清楚我们正在构建一个通过隐式转换对象。classFoo{explicitFoo(std::initializer_listilist){/*...*/}}; 最佳答案 你不能。它确实导致意外的隐式转换。但是,意外的隐式转换是不允许的,编译器将拒绝您的程序。然而,这不会阻止编译器选择或考虑它。示例voidf(Foo);void

华为OD机试题【狼羊过河 or 羊、狼、农夫过河】用 C++ 编码,速通

最近更新的博客华为od2023|什么是华为od,od薪资待遇,od机试题清单华为OD机试真题大全,用Python解华为机试题|机试宝典【华为OD机试】全流程解析+经验分享,题型分享,防作弊指南华为od机试,独家整理已参加机试人员的实战技巧本篇题解:狼羊过河or羊、狼、农夫过河题目描述一农夫带着m只羊,n只狼过河,农夫有一条可载x只狼/羊的船;农夫在时或者羊的数量大于狼时,狼不会攻击羊;农夫在不损失羊的情况下,运输几次可以完成运输?(返程不计入次数)输入描述输入参数为m,n,x;m为羊的数量、n为狼的数量、x为可载狼和羊的数量输出描述返回运输次数

c++ - 错误 : jump to label 'foo' crosses initialization of 'bar'

以下C++示例无法使用gcc或clang进行编译,但仅使用ICC生成警告,而使用MSVC则完全不生成任何警告:intmain(intargc,char*argv[]){if(argcg++:init.cpp:13:error:jumptolabel‘clean_up’init.cpp:4:error:fromhereinit.cpp:7:error:crossesinitializationof‘inti’clang++:init.cpp:4:9:error:cannotjumpfromthisgotostatementtoitslabelgotoclean_up;^init.cpp:

c++ - 找不到 boost_process cmake find_package

我正在尝试将boost库导入我的C++项目,但出于某种原因它找不到Boost.Process,尽管它找到了其他库。我的CMakeLists.txt文件:cmake_minimum_required(VERSION3.9FATAL_ERROR)set(PROJECT_NAME"test-stuff"CXX)project(${PROJECT_NAME})set(Boost_USE_MULTITHREADEDON)find_package(Boost1.64.0REQUIREDsystemfilesystemprocess)if(Boost_FOUND)include_directorie

C++ MPL or_, and_ 实现

我正在尝试阅读boostheader以弄清楚它们是如何实现的or_和and_元函数使得:1)他们可以有任意数量的参数(好吧,最多可以说5个参数)2)它们具有短路行为,例如:or_不实例化true_之后的任何内容(因此也可以声明但不定义)不幸的是,预处理器元编程让我无法完成任务:P提前感谢您的任何帮助/建议。 最佳答案 这是短路如何适用于三参数版本templatestructor_:conditional>::type{};也就是说,如果T1::value是真的,它继承了true_,否则它继承or.你需要一个停止标准,就像@begem

如何使用strspn模仿std :: string的find_first_not_of

我正在尝试创建类似于std::String的自定义字符串类。而且我在实现“find_first_not_of”时遇到了麻烦。这是我的测试代码#includeclassString{private:char*m_data;intm_length;char*alloc(intsize);intlength()const{returnm_length;}intsize()const{returnm_length;}constchar*c_str()const{returnm_data;}public:String(constchar*str=0);intfind_first_not_of(const

c++ - 段错误 : "...no such file or directory"

我遇到了奇怪的段错误,它似乎来自某个不在我的程序中的地方……无论如何都没有明确说明。我在两个数组上调用“strcmp”...两个数组都存储在相同类型的结构中。我得到一个点符号和一个通过“->”取消引用:intname=strcmp(one.name,two->name);它编译得很好,但是当我运行它时,我遇到了段错误。我试过用GDB跟踪它,但是当我在我认为它应该发生的地方之前放置断点时,它无论如何都会出现故障。我得到:ProgramreceivedsignalSIGSEGV,Segmentationfault.__strcmp_ia32()at../sysdeps/i386/i686/

c++ - 扭曲的逻辑 : a global variable in one file refers to an extern variable but is also referred by that extern variable

文件A.cpp:#includeexternintiA;externintiB=iA;intmain(){std::cout文件B.cppexternintiB;externintiA=2*iB;编译链接运行,out进来debug和release模式是0,0我的问题是它是如何工作的,为什么在链接阶段没有问题?我正在使用VC++2003。 最佳答案 初始化程序覆盖了extern关键字,因此这没有什么“神奇”:您只是在不同的翻译单元中声明和定义两个完全不相关的变量。来自StandardforProgrammingLanguageC++-

c++ - initializer_list 返回的生命周期延长

所以我有一个返回类型为auto的lambda我在支持initializer_list的阵列方面遇到问题在这里被摧毁:constautofoo=[](constauto&a,constauto&b,constauto&c){return{a,b,c};};我将像这样使用lambda:autobar=foo(1,2,3);for(constauto&i:bar)cout我正在从事的一项工作将所有lambda表达式作为单一语句作为其编码标准的一部分(请随意表达您的愤怒。)我认为我可以通过以下方式解决这个问题:给予foovectorint的返回类型,但这搞砸了它的通用性:constautofo