草庐IT

private_struct

全部标签

c++ - "Member is private"虽然我不从外部访问它,但在使用尾随返回类型时

如何解决以下问题?我正在编写一些函数库,它定义了以下与这个问题相关的函数:call(f,arg):调用带有参数的函数。只是我在某些情况下需要的包装器。comp(f1,f2):返回两个函数的组合。返回表示两个函数组合的辅助仿函数。实现如下所示(简化版本仍能说明问题)://Callfwithoneargumenttemplateautocall(constFn&f,constArg&arg)->decltype(f(arg)){returnf(arg);}//HelperfunctorforthefunctionbelowtemplateclassCompFn{Fn1a;Fn2b;publ

C++:私有(private)嵌套类类型的公共(public)成员

我有以下代码:classBase{private:classNestedBase{public:voidDo(){}};public:NestedBasenested;};intmain(){Baseb;b.nested.Do();//lineAcompilesBase::NestedBaseinstance;//lineBdoesn'tcompile}NestedBase类是Base的私有(private)嵌套类,因此B行不编译似乎很自然。但是,另一方面,变量b有公共(public)成员nested,我可以从外部调用它的方法Do()>Base(如A行)。在这种情况下,规范对私有(pr

c++ - 'struct ListNode' 类型的空指针内的成员访问

structListNode{intval;ListNode*next;ListNode(intx):val(x),next(NULL){}};classSolution{public:boolhasCycle(ListNode*head){if(head==NULL)returnfalse;ListNode*walker=head;ListNode*runner=head;while(runner->next!=NULL&&walker->next!=NULL){walker=walker->next;runner=runner->next->next;if(walker==runn

c++ - C/C++ : Packing or padding data in a struct

我正在使用带有GNUGCC编译器的Code::BlocksIDE。structtest{chara;chare;charf;charb;chard;};sizeof(test)返回5。我读了这个答案:Whyisn'tsizeofforastructequaltothesumofsizeofofeachmember?为什么最后一个char后没有填充,所以sizeof(test)返回6或8?添加short和int等后,我可以问更多的问题。但我认为这个问题现在很好。填充不会使处理器更容易处理结构吗? 最佳答案 char的对齐方式仅为1,因

c++ - 将前向声明的 C-struct 定义为 C++-struct

将struct前向声明为C-struct是否合法?//api.h#ifdef__cplusplusextern"C"{#endiftypedefstructhandle_taghandle_t;handle_t*construct();voiddestruct(handle_t*h);voidfunc(handle_t*h);#ifdef__cplusplus}#endif然后将其定义为C++-struct,即非POD类型?//api.cppstructhandle_tag{voidfunc();std::stringmember;};voidfunc(handle_t*h){h->f

c++ - C/C++ : Pointers within Const Struct

如何在函数fn中强制obj->val1指向的内存的常量性?#includestructfoo{int*val1;int*val2;int*val3;};voidfn(constfoo*obj){//Idon'twanttobeabletochangetheintegerthatval1pointsto//obj->val1=newint[20];//Ican'tchangethepointer,*(obj->val1)=20;//ButIcanchangethememoryitpointsto...}intmain(intargc,char*argv[]){//Ineedtobeabl

c++ - 为什么 COM DLL 导出应标记为 "PRIVATE"?

在构建COMDLL时,为什么要导出DllGetClassObject、DllCanUnloadNow、DllRegisterServer、DllUnregisterServer等。在关联的.DEF文件的EXPORTS部分中标记为PRIVATE? 最佳答案 当您构建一个DLL时,链接器会自动为该DLL创建一个导入库。它包含所有导出函数的列表。您在另一个使用DLL的项目中使用该导入库。特定于COM服务器的是,这4个导出函数总是通过GetProcAddress()找到,并且您永远不会隐式依赖于COMdll。您始终使用CoCreateIns

c++ - BOOST_FUSION_ADAPT_STRUCT 的限制

我尝试使用BOOST_FUSION_ADAPT_STRUCT宏并尝试了一些简单的操作,例如使用Fusion打印任意结构。从此examplecodegiveninthedocumentation开始,我无法在我的改编结构上执行融合序列允许的一些操作。#include#include#include#include#includenamespacefuz=boost::fusion;namespacedemo{structemployee{std::stringname;intage;};}//demo::employeeisnowaFusionsequenceBOOST_FUSION_A

c++ - 具有私有(private)构造函数和自身静态数组的类

抱歉,如果标题令人困惑,我找不到简单的方法来用简单的句子来写它。无论如何,我面临的问题://header:classSomeThing{private:SomeThing(){}//lookup_table_0;staticSomeThinglookup_table_1[64];};getThatThing函数旨在从查找表中返回一个实例。//intheimplementationfile-definitionsoflookuptablesstd::arraySomeThing::lookup_table_0;//errorSomeThingSomething::lookup_table

c++ - C++中 protected 和私有(private)派生之间的区别是什么

这个问题在这里已经有了答案:关闭11年前。PossibleDuplicate:Differencebetweenprivate,publicandprotectedinheritanceinC++在C++中派生为protected或private有什么区别?我想不通,因为两者似乎都限制从派生类对象访问基类成员