草庐IT

initial_value

全部标签

c++ - *v8::String::Utf8Value(args[0]->ToString()) 不返回 node.js 插件参数的字符串

我发现*v8::String::Utf8Value(args[0]->ToString())在Node0.8.232位上返回正确的字符串,但在Node0.8上不返回正确的字符串。8个64位。有人知道为什么吗?我的node.js插件看起来像这样:#defineBUILDING_NODE_EXTENSION#include#defineMAX_OUTPUT_BUF80extern"C"char*do_sqlsig(char*in);usingnamespacev8;HandleSqlsig(constArguments&args){HandleScopescope;char*c_arg,*

c++ - unordered_map - {{key,value},{key,value}} 语法无效

我正在尝试编译thecodetakenfromhere//constructingunordered_maps#include#include#includetypedefstd::unordered_mapstringmap;stringmapmerge(stringmapa,stringmapb){stringmaptemp(a);temp.insert(b.begin(),b.end());returntemp;}intmain(){stringmapfirst;//emptystringmapsecond({{"apple","red"},{"lemon","yellow"}}

c++ - 我们什么时候应该使用圆括号 ( ) 与 initializer { } 语法来初始化 C++11 中的对象?

这个问题在这里已经有了答案:Whentousethebrace-enclosedinitializer?(3个答案)关闭6年前。已更新我已经通过链接(例如Whentousethebrace-enclosedinitializer?)了解何时应该使用{}大括号初始化,但没有给出何时应该使用括号()的信息与初始值设定项{}在C++11/14中初始化对象的语法?建议使用哪些标准做法()在{}?在极少数情况下,例如vectorv(10,20);或autov=vector(10,20);,结果是std::vector有10个元素。如果我们使用大括号,结果是std::vector有2个元素。但这取

c++ - 解决 "only static const integral data members can be initialized within a class"编译错误

以下创建全局对象会导致编译错误。#include"stdafx.h"#includeusingnamespaceSystem;usingnamespacestd;#pragmahdrstopclassTester;voidinput();classTester{staticintnumber=5;public:Tester(){};~Tester(){};voidsetNumber(intnewNumber){number=newNumber;}intgetNumber(){returnnumber;}}TestertesterObject;voidmain(void){cout>ne

c++ - std::unique_ptr 删除函数,initializer_list - 驱动分配

全部,当我使用初始化列表格式实例化小部件数组时,指向成员变量小部件实例的裸指针可以编译,但在更改为std::unique_ptr后,gcc会给出有关已删除函数的编译错误。$uname-aLinux..3.5.0-21-generic#32-UbuntuSMP2012年12月11日星期二18:51:59UTCx86_64x86_64x86_64GNU/Linux$g++--versiong++(Ubuntu/Linaro4.7.2-5ubuntu1)4.7.2此代码给出以下编译器错误:#include#includeclassWidget{public:Widget(){}};class

c++ - std::initializer_list 的底层结构是什么?

第一部分:std::initializer_list是C++11的一个非常有用的特性,所以我想知道它是如何在标准库中实现的。从我读到的here,编译器创建一个T类型的数组并给出指向initializer_list的指针.它还声明复制initializer_list将创建一个引用相同数据的新对象:为什么会这样?我会猜到它要么:为新的initializer_list复制数据将数据的所有权转移到新的initializer_list第二部分:来自std::vector的众多在线引用资料之一构造函数:vector(initializer_listil,constallocator_type&al

c++ - 候选函数不可行 : expects an l-value for 3rd argument

使用递归函数myPowerFunction(intp,intn,int¤tCallNumber)计算P的n次方(p和n均为正整数)。currentCallNumber是一个引用参数,存储到目前为止进行的函数调用次数。myPowerFunction返回p的n次方。intmyPowerFunction(intp,intn,int&z){z++;if(n==1)returnp;elseif(n==0)return1;elseif(n%2==0)returnmyPowerFunction(p,n/2,z)*myPowerFunction(p,n/2,z);elsereturnmyP

c++ - 开关盒 : declaration-with-initialization & declaration-and-then-assignment

在switch-case语句中,declaration-with-initialization是无效的,但允许declaration-and-then-assignment。如以下代码片段所示。从编译器端看,这两种类型的初始化有什么区别?以及为什么第一种初始化无效而第二种初始化有效。switch(val){case0:intnewVal=42;//Invalidbreak;case1:intnewVal2;//ValidnewVal2=42;break;case2:break;} 最佳答案 实际上,规则是您不能跳入经过具有初始化的声

c++ - 为什么这段将字符串初始化为单个字符的代码会调用 initializer_list 构造函数?

我最近在做一个C++项目,遇到了一个边缘案例,其中包含我无法完全理解的字符串构造函数。相关代码(youcanrunhere)如下:#include#includeusingnamespacestd;intmain(){stringdirectParens(1,'*');stringdirectBraces{1,'*'};stringindirectBraces={1,'*'};cout字符串的大括号初始化版本最终包含两个字符,即一个char,其数值为1,后跟一个星号。我不明白为什么字符串的大括号初始化版本调用initializer_list构造函数,而不是构造函数接受一个大小和一个字符

c++ - 最快的 C++ 容器 : Unique Values

我正在编写一个与MySQL数据库交互的电子邮件应用程序。我有两个表来获取我的数据,其中一个包含取消订阅,另一个是标准用户表。截至目前,我正在创建一个指向电子邮件对象的指针vector,并将所有未订阅的电子邮件存储在其中,最初是这样。然后我有一个标准的SQL循环,我在其中检查电子邮件是否不在取消订阅vector中,然后将其添加到全局发送电子邮件vector中。我的问题是,是否有更有效的方法来做到这一点?我必须为系统中的每一封电子邮件搜索unsubvector,最多5万封不同的邮件。是否有更好的搜索结构?并且,一个更好的结构来维护一个独特的值(value)集合?如果它已经包含它,也许会简单