草庐IT

default-copy-constructor

全部标签

android - FragmentPagerAdapter 的麻烦和困境 : Constructor Undefined

编辑:我修改了一些代码以尝试克服错误(但现在应用程序在启动时崩溃)。首先,我的类现在扩展了FragmentActivity,这样我就可以访问方法getSupportFragmentManager();。然后,在创建时,我更改了构造函数:mTabsAdapter=newTabsAdapter(this.getSupportFragmentManager(),this,mViewPager);从那里开始,在我的子类中,我更改了代码以反射(reflect)这一点:publicTabsAdapter(FragmentManagerfm,Activityactivity,ViewPagerpag

c++ - 无法解析类型 'std::default_random_engine'

我想在header随机中使用default_random_engine和uniform_real_distribution生成一些随机双数。我使用EclipseforC/C++&MinGW来构建我的项目。Eclipse版本:4.2.1EclipseCDTC/C++开发工具版本:8.1.1.201209170703EclipseCDTGCC交叉编译器支持版本:1.1.0.201209170703MinGW版本:4.6.2(使用“gcc-v”检查)当我在编辑器中键入std::default_random_engine时,Eclipse提示我“Type'std::default_random

c++ - 列出聚合的初始化 : when can it invoke copy constructor?

考虑以下代码:structA{intx;};intmain(){Aa;Ab{a};}这个程序在C++11标准下是否良构?在我的N3797拷贝中它说8.5.4Listinitialization[dcl.init.list]3:List-initializationofanobjectorreferenceoftypeTisdefinedasfollows:-IfTisanaggregate,aggregateinitializationisperformed(8.5.1).-Otherwise,ifTisaspecializationofstd::initializer_list,..

c++ - std::copy/memcpy/memmove 优化

我查看了GCCSTL(4.6.1)并看到了std::copy()使用优化版本以防内置__is_trivial()评估为true.自std::copy()和std::reverse_copy()模板对于复制数组中的元素非常有用,我想使用它们。但是,我有一些类型(它们是模板实例化的结果)是包含一些微不足道的值、没有指针并且没有复制构造函数或赋值运算符的结构。G++是否足够聪明,可以弄清楚我的类型实际上是微不足道的?在C++98中有没有什么方法可以确保STL实现知道我的类型是微不足道的?我想在C++11中,使用is_trivial会变得很方便类型特征。这样对吗?谢谢!编辑:抱歉来得太晚了,但

c++ - std::move( ) 在没有 move-ctor 的情况下调用 copy-ctor。为什么以及如何预防?

我想知道是否有一种安全编程实践可以在这种微妙的行为发生时提醒编码人员,或者更好的是,首先避免这种行为。structA的用户可能没有意识到没有move构造函数。在他们尝试调用不存在的ctor时,他们既没有收到编译器警告,也没有收到任何运行时指示调用了复制ctor。下面的答案解释了发生的转换,但我看不出这是一件好事的任何理由。如果缺少以const引用作为参数的构造函数,则会出现编译时错误,而不仅仅是解析为非常量引用版本。那么,当类中没有实现move语义时,为什么尝试使用move语义不会导致编译时错误?有没有办法通过一些编译时选项避免这种行为,或者至少有一种在运行时检测它的方法?在move之

c++ - 使用 std::copy 的问题

我在使用标准复制功能时收到警告。我声明了一个byte数组。byte*tstArray=newbyte[length];然后我有几个其他字节数组,它们使用一些十六进制值声明和初始化,我想根据一些初始用户输入使用这些值。我有一系列if语句,我使用这些语句基本上解析出原始输入,并基于一些字符串,我选择要使用的字节数组,并在这样做时将结果复制到原始tstArray。例如:if(substr1=="15"){std::cout我得到的警告是警告C4996:“std::copy”:带参数的函数调用那可能不安全-此调用依赖于调用者检查传递的值是正确的。我认为,一个可能的解决方案是使用-D_SCL_S

c++ - 使用 C++ 写入二进制文件 : does the default locale matter?

我的代码使用设置了二进制标志的fstream和使用未格式化的I/O函数读取和写入来操作二进制文件。这在我曾经使用过的所有系统上都能正常工作(文件中的位完全符合预期),但这些基本上都是美国英语。我一直想知道这些字节是否可能被不同系统上的codecvt修改。听起来标准说使用未格式化的I/O与使用sputc/sgetc将字符放入streambuf的行为相同。这些将导致调用streambuf中的溢出或下溢函数,并且听起来这些会导致通过某些codecvt的东西(例如,请参阅c++标准中的27.8.1.4.3)。对于basic_filebuf,此codecvt的创建在27.8.1.1.5中指定。这

c++ - 为什么 std::copy(从 istream 到 ostream)会引发 ios::failure 异常?

以下代码应将数据从wifstream复制到wcout。复制内容后,程序抛出ios::failure异常。#include#include#include#include#include#include#includeintmain(void){std::locale::global(std::locale(""));std::wifstreamis;is.exceptions(std::ios::failbit|std::ios::badbit);is.open("test.ts",std::ios::binary);is>>std::noskipws;std::istream_ite

c++ - std::copy_n 是否适用于重叠范围?

我正在查看N348525.3.1[alg.copy]中的C++标准,它定义了4种算法:复制copy_backwardcopy_ifcopy_n在copy的描述中,有这个注释25.3.1[alg.copy]/3:Requires:resultshallnotbeintherange[first,last)也就是说,当范围重叠时,copy并不总是正确工作(类似于memcpy)。copy_backward和copy_if有相似的语言禁止重叠范围(分别为25.3.1[alg.copy]/14和25.3.1[alg.copy]/8).但是copy_n没有这样的禁止,也没有copy_n_backw

c++ - has_trivial_default_constructor 是如何工作的?

谁能给我解释一下has_trivial_default_constructor是如何工作的?我试图在提升实现中找到它,但不幸的是宏太多,我迷路了......如何使用模板检测C++中的trivial_default_constructor?我需要一个C++03而非11的示例。#include#includestructA{A(){}inta;//std::vectorb;};intmain(intargc,char*argv[]){structB{std::vectorb;};boolresult=boost::has_trivial_default_constructor::value