草庐IT

public_send

全部标签

c++ - 用私有(private)基函数覆盖公共(public)虚函数?

让我们考虑具有以下接口(interface)的两个类A和B:classA{public:virtualvoidstart(){}//defaultimplementationdoesnothing};classB{public:voidstart(){/*dosomestuff*/}};然后是从两者继承的第三个类,A是公开的,因为它实现了这个“接口(interface)”,B是私有(private)的,因为那是实现细节。但是,在这个特定的实现中,start()只需要包含对B::start()的调用。所以我想我可以使用快捷方式并执行以下操作:classC:publicA,privateB

c++ - 具有混合继承修饰符的菱形继承(钻石问题)( protected /私有(private)/公共(public))

假设我们有类A、B、C、D,其中A是基础,B、C是介于两者之间,D是在菱形模型中派生的。注意:classB在private模式下继承virtualyclassA,C类在保护模式下继承虚拟A类。classA{public:intmember;//notethismember};classB:virtualprivateA//noteprivate{};classC:virtualprotectedA//noteprotected{};classD:publicB,//doesn'tmetterpublicorwhateverherepublicC{};intmain(){Dtest;te

c++ - 按公共(public)元素对列表进行分组

我正在寻找一种聪明/快速的C++算法,当它们包含公共(public)对象时,它允许我对多个对象列表进行分组。假设我有N个列表,每个列表包含与一个元素E关联的1..M个对象(O):[O1,O2]->E1[O3]->E2[O1,O4,O5]->E3[O2,O5]->E4[O3,O6]->E5我希望将它们重新排列成以下内容:[O1,O2,O4,O5]->[E1,E3,E4][O3,O6]->[E2,E5]结果将所有公共(public)对象与所有关联元素组合在一起。列表之间最终没有共享对象。 最佳答案 对于每个对象,计算哪些元素包含它。即0

c++ - 如何在 MPI_Send 中发送一个集合对象

我搜索发送一个set对象,我发现最接近的是vector(它不同,不适用于set)。如何在MPI_Send中发送一个集合对象?(不使用boost库)任何人都可以举一个简单的例子吗? 最佳答案 在MPI中,无论是将复杂的数据结构写入文件还是通过网络,问题都是一样的;您必须将数据提取到“普通旧数据”(POD)中,保存它,然后输出它,同样能够将保存的数据解压缩为相同类型的结构。通常,这称为序列化。对于任何给定的结构,您始终可以编写自己的例程来执行此操作,但在C++中,Boost中有一个名为BoostSerializationLibrary的

c++ - 提供 protected 模板成员函数的公共(public)特化

我想做以下事情:classFoo{protected:templatevoidoperator()(constParam¶m){//stuffinvolvingsomeRTTImagic}public:voidoperator()(constA¶m)shouldbeoperator();voidoperator()(constB¶m)shouldbeoperator();}基本上,我有一个带有通用模板参数的通用operator()。但是,我只想发布类型安全的特定专业。谢谢! 最佳答案 只是给私有(privat

c++ - union 中的标量成员是否计入公共(public)初始序列?

在下面的unionU中,如果a或b是活跃成员,是否定义了访问c?structA{inta;};structB{inta;doubleb;};unionU{Aa;Bb;intc;};在[class.union],该标准定义了一些规则,使使用union更容易(强调我的):[ Note:Onespecialguaranteeismadeinordertosimplifytheuseofunions:Ifastandard-layoutunioncontainsseveralstandard-layoutstructsthatshareacommoninitialsequence,andifa

c++ - 按 C++ 中的公共(public)/重复元素对 vector 进行分组和排序

假设我有一个vector如下std::vectorv={3,9,7,7,2};我想对这个元素vector进行排序,这样vector将存储为77932。所以首先,我们存储公共(public)元素(7),然后我们将剩余的元素从最高到最低排序。如果我有一个vector如下std::vectorv={3,7,7,7,2};在这里,它将导致77732。同样std::vectorv={7,9,2,7,9};它应该导致99772,因为9比7高。最后一个例子std::vectorv={7,9,7,7,9};它应该导致77799,因为7比9多。最快的算法是什么? 最佳答案

c++ - 为什么继承的 protected operator=() 具有公共(public)访问权限

声明为protected的重载运算符=对于继承父类作为public的子类是公开可访问的。#includeclassA{public:A(charc):i(c){}chari;protected:A&operator=(constA&rdm){std::cout编译时没有错误:$g++-Wall-otest_operator~/test_operator.cpp$./test_operatora.i==aaccessingoperator=()a.i==x直接使用A是编译不过的。operator=()以外的任何其他运算符重载都不会编译。使用g++4.4.7和7.3.0以及c++98和c+

java - 公共(public)方法中的私有(private)参数

当非私有(private)方法的参数是私有(private)类型(例如,私有(private)嵌套类)时,g++和javac都不会发出警告。此类方法不能由客户端使用,但它们可以作为类的公共(public)API的一部分出现。在C++中,将此类方法放入类Foo的公共(public)部分,例如,可以允许其他类访问这些方法,而无需明确列为类Foo中的友元(只要它们可以访问用作参数)。但总的来说,不显式地将此类方法设为私有(private)是否是不好的风格,还是可以将其忽略?(反正客户端用不了,有什么大不了的) 最佳答案 这是允许的,也可能

c++ - 如何优化最长公共(public)子序列的 O(m.n) 解决方案?

给定两个字符串,长度为x1的字符串X和长度为y1的字符串Y,找出两个字符串中从左到右(但不一定在连续block中)出现的最长字符序列。e.gifX=ABCBDABandY=BDCABA,theLCS(X,Y)={"BCBA","BDAB","BCAB"}andLCSlengthis4.我使用了这个问题的标准解决方案:if(X[i]=Y[j]):1+LCS(i+1,j+1)if(X[i]!=Y[j]):LCS(i,j+1)orLCS(i+1,j),whicheverisgreater然后我使用了内存,使它成为一个标准的DP问题。#include#includeusingnamespace