草庐IT

pair_of_ints

全部标签

c++ - 用 int main(void) 编译失败; main(int argc, char *argv[]) 成功。为什么?

问题为什么编译具有intmain(void)main函数的程序与编译具有intmain(intargc,char*argv[])主函数,如果程序不使用命令行传递的参数?这个操作系统或编译器是特定的吗?我没有使用mingw和g++得到相同的结果(这很奇怪不是因为wingw是gcc的一个端口)。例子代码#include#include"SDL/SDL.h"intmain(void){return0;}编译命令g++test.cpp;#g++4.4.5i586-mingw32msvc-g++test.cpp;#mingw4.4.4错误(由第二个命令给出。)a(main.o):(.text+0

c++ - 使用迭代器将 int 值赋给 vector

我在C++Primer(3.23)中进行了将近2天的小练习。我试过很多方法给vector赋值.我给你一个我工作的实际练习和我到目前为止的代码,但它是完全错误的。我做了很多研究,但没有发现任何有用的东西。编写程序创建一个vector与10int元素。使用迭代器,为每个元素分配一个为其当前值两倍的值。通过打印vector来测试程序这是我的代码intmain(){vectornum(10);for(autoit=num.begin();it!=num.end();++it)//iteratingthrougheachelementinvector{*it=2;//assignvaluetov

C++:int64_t 它来自哪里?

这个问题在这里已经有了答案:Definitionofint64_t(5个答案)关闭9年前。我想知道像int64_t这样的类型是从哪里来的。它们是C++标准的还是操作系统相关的?(1)此外,您知道在哪里可以找到有关这些类型的文档吗?到目前为止我找不到有用的信息。他们有特别的名字吗?(2)它们与int、long等标准原始类型的一般区别是什么...(3)谢谢你和问候

c++ - 为什么 is_base_of 都只是普通的 char 类型时会失败

你明白为什么static_assert失败了吗:templatevoidfoo(constT&c){static_assert(std::is_base_of::value,"Tmustbechar");//Fails!}intmain(){charc='a';foo(c);return0;}我交换了T和“char”,仍然失败。 最佳答案 您可能需要考虑添加额外的检查:templatevoidfoo(constT&c){static_assert(std::is_base_of::value||std::is_same::value

c++ - 为什么 'control reaches end of non-void function' 只是一个警告?合法吗?

这个问题在这里已经有了答案:WhydoesthisC++snippetcompile(non-voidfunctiondoesnotreturnavalue)[duplicate](7个答案)关闭8年前。C++定义具有非void返回类型的函数允许控制到达函数末尾而不是到达return语句是否合法?gcc和clang仅为此发出警告。这样做的代码是合法的还是这些编译器只是慷慨?海湾合作委员会:warning:noreturnstatementinfunctionreturningnon-void[-Wreturn-type]clang:warning:controlreachesendof

c++ - 为什么int/int = int?

关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭7年前。Improvethisquestion为什么当我除以两个整数时结果是整数而不是float,为什么选择这个设计决策?

C++ typedef a std::pair 然后使用typedef声明一个映射

假设我有这个typedeftypedefstd::pairMyType;那么,如果我也想使用MyType创建map,我该怎么做呢?我不想重新键入这对中的两种类型,例如:mapmyMap;我想要这样的东西:mapmyMap;有没有办法使用我的typedefMyType而不是重新键入类型来做到这一点? 最佳答案 简单...std::mapmyMap;参见http://en.cppreference.com/w/cpp/utility/pair示例程序位于coliru 关于C++typedef

c++ - 将 std::function<int(int)> 赋值给 std::function<const int&(const int& x)>

以下代码编译但在VC++2015(发行版)中产生未定义的输出和运行时错误othercompilers.#include#includeintmain(){std::functionf=[](intx){returnx;};std::functiong=f;std::cout为什么赋值g=f;是允许的? 最佳答案 考虑重写等效代码以避免lambda或std::function:intf(intx){returnx;}intconst&g(intconst&x){returnf(x);}这是一个结构良好的代码,尽管如此,它仍会返回一个对

C++11 在 map<key, value> 中为值(int 和 string)存储多种数据类型的最简单方法?

我想要一个使用的map键字符串值的整数或字符串像这样:std::mapmyMap;myMap["first_key"]=10;myMap["second_key"]="stringValue";做这种事情的最简单方法是什么?已添加)我正在寻找适用于C++11的解决方案 最佳答案 在c++17中,你可以使用std::variant,在此之前,您可以使用boost中的那个:usingIntOrString=std::variant;std::mapmyMap;myMap["first_key"]=10;myMap["second_key

c++ - 概念 : checking signatures of methods with arguments

我一直在研究概念。这是一个最小的例子,我试图在其中创建一个基于方法签名的概念:templateconceptboolmyConcept(){returnrequires(Ta,inti){{a.foo()}->int;{a.bar(i)}->int;};}structObject{intfoo(){return0;}intbar(int){return0;}};static_assert(myConcept(),"ObjectdoesnotadheretomyConcept");令我惊讶的是,编写{a.bar(int)}->int不起作用,所以我求助于向requires表达式添加一个额