草庐IT

copy_from_local

全部标签

c++ - C4244 : '+=' : conversion from 'std::streamsize' to 'size_t' , 可能丢失数据

我已将我的VC++项目从VS2008迁移到VS2013并收到一些警告,例如:C4244:'+=':conversionfrom'std::streamsize'to'size_t',possiblelossofdata.如何解决这些类型的警告? 最佳答案 在MSVC2013中std::streamsize是:typedef_Longlongstreamsize;typedef_LONGLONG_Longlong;#define_LONGLONG__int64size_t是:typedefunsigned__int64size_t;因

c++ - CMake : softlink resource ( such as GLSL shaders ) or copy each complilation

使用CMake将资源从源目录复制到构建目录的最简单方法是file(COPY${CMAKE_CURRENT_SOURCE_DIR}/resourcesDESTINATION${CMAKE_CURRENT_BINARY_DIR})但是,这仅当我调用cmake时才会更新构建目录中的资源。我需要每次调用make来更新资源。例如现在我开发了一些GLSL着色器。我需要同时更改C++代码和GLSL代码,并且我需要在我的IDE中每次点击compile或run时一切都同步(我将CodeBlocks与CMake生成的项目文件一起使用)简单的解决方案是使从源目录到构建目录的软链接(softlink)。但我不

c++ - 为第二个范围内的重复项设置差异,替代 remove_copy

我有两个数组或vector,比如说:intfirst[]={0,0,1,1,2,2,3,3,3};intsecond[]={1,3};我想去掉第一组中的1s和3s,set_difference只能去掉这些值的第一次出现,但这不是我想要的。我是否应该通过迭代第二个范围并每次从第一个集合中删除一个条目来使用remove_copy来执行此操作。在C++中执行此操作的最佳方法是什么? 最佳答案 写一个专门的set_difference:templateOutputIteratorset_difference_any(InputIterato

c++ - 严格的别名规则和 std::copy

我有一个字符数组,其中包含我需要解释为“int”的“序列化”数据。以前我只是将指向位置的指针转换到“int*”并取消引用以获取int数据,但尽管它对我来说效果很好,但它打破了严格的别名规则,因此出现了未定义的行为。所以现在我使用memcpy将字节复制到一个int中,我相信这不是未定义的行为。但是我可以使用“std::copy”吗?例如chardata[10]={0,1,2,3,4,5,6,7,8,9};inti;std::copy(data,data+sizeof(int),reinterpret_cast(&i));这本身并没有违反严格的别名规则,但任何可能的实现都会这样做.....

c++ - 警告 : base class ‘A’ should be explicitly initialized in the copy constructor

我有以下类结构:classA{A(){}A(constA&src){}};classB:virtualA{B():A(){}B(constB&src):A(src){}};classC:virtualA{C():A(){}C(constC&src):A(src){}};classD:virtualB,virtualC{D():B(),C(){}D(constD&src):B(src),C(src){}};这给了我警告:Incopyconstructor‘D’:warning:baseclass‘A’shouldbeexplicitlyinitializedinthecopyconstr

c++ - JNI : How to convert a group of data from c++ to Java

我正在尝试使用JNI将一些数据从C++发送到Java。在C++中我有:Array[0]:stringname="myName"intiterations=16floatvalue=15...etc所以我想使用JNI返回Java上的所有数据,我正在尝试这个,但不起作用JNIEXPORTjobjectArrayJNICALLJava_com_testing_data_MainActivity_getDATA(JNIEnv*env,jobjectobj){//1ºCreateatempobjectjobjectdataClass{jstringname;jintiterations;jflo

c++ - 谷歌 V8 : access local variables in C++

有人知道如何在C++的嵌套函数调用中查找局部变量吗?考虑以下示例://e.g.aglobalvariableinthebrowservarglobal="global_value";functionfoo(){varglobal="local_value";myCppFunction("global",global);}foo();我现在的问题是,在myCppFunction的实现中,我如何从“foo”访问函数局部变量“global”(不是值,这将由第二个参数给出)?HandleMyCppFunction(constArguments&args){LocalvarName=args[0

C++ 编译器错误 "cannot be thread-local because it has non-POD type”“

这个声明:___threadAa;生成此错误:cannotbethread-localbecauseithasnon-PODtypeA在哪里classA{public://functiondeclarationprivate://datamembers};我正在尝试使用命令ogsincludes&ogsmk在Linux上进行编译。我们有静态线程,即在我们的应用程序进入之前,我们知道线程的数量,因此目前的工作是通过声明A的数组来完成的,即Aa[Numberofthreads].我该如何解决这个问题? 最佳答案 假设您使用gcc,线程本

C++ : generate all subsets from set with one condition

我正在尝试编写代码,通过一个条件从集合中生成所有子集,例如如果我有threshold=2,并且设置了三个:1,2,3,4,51,3,51,3,4然后程序会输出:第一次迭代时的生成集:1=numberoffrequency=32=numberoffrequency=13=numberoffrequency=34=numberoffrequency=25=numberoffrequency=2由于数字2第二次迭代时的生成集:1,3=numberoffrequency=31,4=numberoffrequency=21,5=numberoffrequency=23,4=numberoffre

c++ - 为什么 std::copy 不向量化?

考虑这个通用代码:#include#include#include//std::copyintmain(){constintn=1024;floata1[n],a2[n];std::srand(std::time(0));for(inti=0;i当我在Ubuntu上使用g++/gcc4.8.1和-O3-march=native-mtune=native标志编译时,我得到对应的行无法对拷贝进行矢量化,因为:note:notvectorized:notenoughdata-refsinbasicblock.如果我用for(inti=0;i我也收到了相同的编译器消息。我有点不解。直觉上我会想