草庐IT

copy-protection

全部标签

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

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

c++ - 为什么我不能访问作为参数传递给函数的基类的 protected 成员变量?

This答案似乎表明它应该可以工作,那么为什么我的示例会引发编译器错误:classClass1{protected:longm_memberVar;};classSubClass1:publicClass1{public:voidPrintMember(Class1memberToPrintFrom){Console::Write("{0}",memberToPrintFrom.m_memberVar);//[编辑]-根据Need4Sleep的建议将子类更改为公共(public)继承,但这没有区别。 最佳答案 在这个答案中,我假设您

C++ 私有(private)和 protected 虚方法

为了分离两个客户端的接口(interface),将虚拟方法设为私有(private)似乎是件好事-1.实例化对象并调用方法的客户端2.派生自该类并可能想要覆盖该方法的客户。简单地说——第一个客户不需要知道一个方法是否是虚拟的。他将调用基类公共(public)非虚拟方法,该方法又将调用私有(private)虚拟方法。例如,请参见下面的代码。现在,如果虚方法需要向其基类的相应虚方法发送super消息,例如Save方法-它必须通过继承链中的所有虚方法才能保存对应的数据每个派生级别-我们别无选择,只能使用protected虚拟方法-除非有一种方法可以保证在所有派生级别保存数据而不使用super

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++ - 错误 : base class 'A1' has private copy constructor

在windows平台上使用Clang3.7见以下代码:classA1{public:A1(char*name){}virtual~A1(){}private:A1(constA1&){}};classB1:publicA1{public:B1():A1(""){}};我收到以下错误:MyFile(31):8:error:baseclass'A1'hasprivatecopyconstructorB1():A1(""){}^MyFile(25):2:note:declaredprivatehereA1(constA1&){}^公开A1复制构造函数,消除错误!这里发生了什么?注意:通过改变

c++ - 如何检查类是否具有默认构造函数,公共(public)的、 protected 或私有(private)的

我需要检查一个类C有一个默认构造函数,可以是隐式的也可以是自定义的,并且可以是public,protected或private.我尝试使用std::is_default_constructible::value,如果C则返回真有一个public默认构造函数(隐式或自定义)但false如果C有一个protected或private默认构造函数(尽管接缝是标准行为。)有什么方法可以检查一个类是否有protected或private默认构造函数?注意(如果这可能有帮助):检查是从friend函数执行的类(class)C待检查。我需要执行此检查以默认构造对应于nullptr的对象m_objs的

c++ - 如何使用 std::copy 读取任意数量的值?

我正在尝试编写与此相反的操作:std::ostreamouts;//properlyinitializedofcoursestd::setmy_set;//dittoouts(outs));应该是这样的:std::istreamins;std::set::size_typesize;ins>>size;std::copy(std::istream_iterator(ins),std::istream_iterator(ins)???,std::inserter(my_set,my_set.end()));但我坚持使用“结束”迭代器——输入交互器不能使用std::advance并且我也不

C++: protected 类构造函数

如果一个类总是要被继承,那么让构造函数protected有意义吗?classBase{protected:Base();};classChild:protectedBase{public:Child():Base();};谢谢。 最佳答案 只有在您不希望客户端创建Base的实例时才有意义,而是您希望它成为某些[derived]类的基类,和/或希望它成为由Base的friend使用(参见下面的示例)。请记住,protected函数(和构造函数)只能从派生类和friend类中调用。classSample;classBase{friend

c++ - 纯虚类中的构造函数应该是 "protected"还是 "public"?

以下示例来自《InsideC++objectmodel》一书classAbstract_base{public:virtual~Abstract_base()=0;virtualvoidinterface()const=0;virtualconstchar*mumble()const{return_mumble;}protected:char*_mumble;};作者说如果我想初始化纯虚基类的数据成员_mumble,应该实现一个“protected构造函数”。但为什么要保护?为什么“publicconstructor”不适合这个类?感谢您的回答,如果有例子就完美了。