草庐IT

libc_start_main

全部标签

c++ - libc++ 的 std::map/set::equal_range 实现给出了意想不到的结果

我注意到clang的libc++中的std::set::equal_range(与std::map相同)给出与libstdc++不同的结果。我一直认为equal_range应该返回等效于std::make_pair(set.lower_bound(key),set.upper_bound(key)),这是cppreference所说的和libstdc++所做的。然而,在libc++中,我有一个代码给出了不同的结果。#include#include#includestructcomparator{usingrange_t=std::pair;usingis_transparent=std

c++ - 如何在 va_start 中使用字符串?

出于某种原因,我无法正常工作:voidexamplefunctionname(stringstr,...){...va_start(ap,str.c_str());我也没有得到这个工作:voidexamplefunctionname(stringstr,...){...intlen=str.length();char*strlol=newchar[len+1];for(inti=0;i但这确实:voidexamplefunctionname(constchar*str,...){...va_start(ap,str);有人可以告诉我如何使用字符串代替constchar*吗?当我调用ex

c++ - 如何在 C++ 中忽略动态链接库中的 main 方法

在我们的应用程序中,我们使用了几个动态链接库。我们最近更新了其中一个库的版本。自这个新版本以来,该库的开发人员提供了一个主要方法(除了打印HelloWorld之外什么都不做)。问题是我们使用的是GTest和GMock,它们生成自己的main方法。当我们现在运行我们的测试二进制文件时,我们只得到“HelloWorld”,所以采用了错误的main方法。我们如何强制使用测试的主要方法?更新:这似乎是一个GMock/GTest问题。main方法正常生成,但不是这样,因为它现在找到了一个已经存在的main方法。 最佳答案 您的情况没有解决办法

c++ - main() 中下面 'i' 的类型。为什么是int&?

我知道main()中i的类型是int&。这就是必须对其进行初始化的原因。int&f(){staticinti=1;returni;}intmain(){decltype(f())i=f();}但使用标准中的段落5p5,我得出结论,表达式f()的类型为int,因为引用被删除了。从7.1.6.2p4开始,假设从函数返回中删除了引用,怎么能说表达式f()是左值? 最佳答案 在评估表达式的类型时(根据§5/5),引用被删除,但这不会改变函数调用表达式f()是一个的事实左值。根据C++11标准的第5.2.2/10段:Afunctioncall

c++ - g++ : can't link with a main executable file

我正在开发一个使用统计攻击来破解wepkey的应用程序。当我用我的makefile编译时(如上)我得到这个错误:ld:can'tlinkwithamainexecutablefile'execStatAttack'forarchitecturex86_64clang:error:linkercommandfailedwithexitcode1(use-vtoseeinvocation)make:*[statAttack]Error1我的项目包含那些文件:statAttack.cpp:包含主要功能,使用上面的文件rc4.h+rc4.cpp:具有那些功能#include#include#i

c++ - libc++ 中的 std::min 没有悬挂引用

众所周知(或者应该是)绑定(bind)std::min的结果到const引用是一个非常糟糕的主意,每当std::min的参数之一时是右值,因为const引用绑定(bind)不会通过函数返回传播。所以下面的代码#include#includeintmain(){intn=42;constint&r=std::min(n-1,n+1);//risdanglingafterthislinestd::cout应该产生未定义的行为,因为r悬空。事实上,在使用-Wall-O3使用gcc5.2进行编译时编译器吐了warning:isuseduninitializedinthisfunction[-W

c++ - 带有 libc++ 异常的 Clang

我一直在试验不同的C++库,并发现了以下内容:简单的应用:#includeintmain(intargc,char*argv[]){try{throw1;}catch(...){std::cout当我像这样在ARM上编译它时:clang++-stdlib=stdlibc++如预期的那样捕获了异常。但是当我把它改成:clang++-stdlib=libc++我不断得到:terminatingwithuncaughtexceptionoftypeintAborted我尝试使用各种标志显式打开异常,例如:-fexceptions-fcxx-exceptions-frtti但是这些标志都不起作

c++ - 关于 main 函数的命令行参数

它看起来像intmain(intargc,char*argv[]);。我的问题是:1我可以在argv[]中添加多少个数组项?2每个char*的最大大小是多少? 最佳答案 你可以试试:$getconfARG_MAX2180000http://pubs.opengroup.org/onlinepubs/007904975/basedefs/limits.h.htmlARG_MAXismaximumlengthofargumenttotheexecfunctionsincludingenvironmentdata.也就是说,对参数的数量或

c++ - 使用 lambda 构造 std::function 时 libstdc++ 和 libc++ 之间的不同行为

这个问题来自thisquestion.以下代码compilesfine将clang3.4与libstdc++结合使用:#includeintmain(){std::functionf=[](){};}但是failsmiserably使用clang3.4和libc++:Infileincludedfrommain.cpp:1:Infileincludedfrom/usr/include/c++/v1/functional:465:Infileincludedfrom/usr/include/c++/v1/memory:599:/usr/include/c++/v1/tuple:320:1

c++ - 如何在 Xcode 中追踪 "libc++abi.dylib: Pure virtual function called!"

我有一个混合使用C++、Objective-C和Swift的多线程OSX应用程序。当我的应用程序关闭时,我在Xcode调试器窗口中看到:libc++abi.dylib:Purevirtualfunctioncalled!我知道这个错误通常是由在C++类构造函数或析构函数中调用虚函数引起的。有没有简单的方法可以找到它的位置?我所说的“简单”是指“不分析每个具有虚函数的类的每个构造函数和析构函数的每一行的调用树”。我没有看到堆栈跟踪。打印此消息时,调试器不会停止程序。从我的应用委托(delegate)的applicationDidTerminate方法记录的消息在此消息之前。我尝试在“所有