草庐IT

private_extern

全部标签

java - OOP 和私有(private)字段的继承

关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭6年前。Improvethisquestion在C#中,规范说:Instanceconstructors,destructors,andstaticconstructorsarenotinherited,butallothermembersare,regardlessoftheirdeclaredaccessibility(§3.5).However,dependingontheirdeclaredaccessibility,inhe

c++ - Windows 上 DLL Exporting/Importing 和 Extern 的问题

我有一些关于Windowsdll的快速问题。基本上我使用ifdefs来处理dllexport和dllimport,我的问题实际上是关于dllexports和dllimports以及extern关键字的放置。我将dllimports/dllexports放在头文件中,但我是否必须将dllexport和dllimports放在实际定义中?对于typedef呢?我是否将dllimport/dllexport放在前面?如dllexporttypedefmapst_map另外关于extern关键字,我看到它被这样使用:extern"C"{dllexportvoidfunc1();}我也看到它被这

c++ - 为什么这个友元函数不能访问类的私有(private)成员?

当我尝试从extractHistogram()实现中访问GHistogram类的bins私有(private)成员时出现以下错误:error:'QVectorMyNamespace::GHistogram::bins'isprivateerror:withinthiscontext其中“在此上下文中”错误指向extractHistogram()实现。有谁知道我的友元函数声明有什么问题吗?代码如下:namespaceMyNamespace{classGHistogram{public:GHistogram(qint32numberOfBins);qint32getNumberOfBins

java - 关于extern "C"的C++到Java的转换问题

我必须将一些C/C++代码转换为Java。我的C++非常生锈。在.h文件中,我有以下内容:#ifdef__cplusplusextern"C"{#endif/*tonsofdeclarations*/#ifdef__cplusplus}/*externC*/#endifextern"C"有什么用?这是什么意思?它是否告诉编译器相应的代码应该被解释为纯C,而不是C++?编辑感谢您到目前为止的回答。我必须转换的代码的历史是,似乎一部分是先用C编写的,然后其余部分是用C++编写的。所以我的头文件似乎对应于“旧”C代码。我会将此代码转换为具有静态方法和属性的publicfinalclass。没

c++ - 'private'访问修饰符是否给了编译器更大的优化空间?

它是否允许编译器内联它,知道只有同一个类中的函数才能访问它?还是只是为了程序员的方便? 最佳答案 编译器可以(但不是必须)按照您的建议进行优化,但这不是要点。访问修饰符的目的是在编译时捕获某些类(没有双关语)的编程错误。私有(private)函数是这样的函数,如果有人从类外部调用它们,那将是一个错误,您希望尽早了解它。(任何时候你问“编译器是否可以根据可用的信息进行优化”这个问题,答案都是“是的,除非标准中有特定的规则说不允许”(例如volatile的规则,其全部目的是抑制优化)。然而,编译器不一定打扰根据任何给定的信息进行优化。毕

c++ - 在类的私有(private)部分声明数组

我有一个类,该类的部分输入是一个可变长度的vector(称为数据)(假设它的长度为N)。我在函数之后包含了这个:N=data_->size();在类的私有(private)部分,我想声明一个数组doubleA[N][N];.但是,当我尝试这样做时,我会听到一些话error:"Nisnotatypename,static,orenumerator".如何创建数组A[N][N]?抱歉,如果这已经在其他地方解释过,因为我是c++的新手,所以甚至不知道要寻找什么!编辑——附加代码:classfoo{public:foo(std::vector&data):data(data_){N=data_

c++ - 允许用户包含类而不包含用于私有(private)的 header

抱歉标题又长又乱。我有一个这样的类头文件#pragmaonce#include#include#includeclassA{public:A();Method1();Method2();private:std::threadthread;boost::asio::socketsocket;another3dpartylib::doodadgizmo;}现在类的用户不会也不应该关心私有(private)部分。我怎样才能允许用户在不拖动的情况下包含类,和?从技术上讲,用户唯一应该关心的是sizeof(A).我错了吗? 最佳答案 C++中

c++ - 在每个源文件中替代 "extern template"

我正在开发一个库,其中我们的许多核心对象都是模板,其中一个特定实例以指向该模板实例的智能指针的形式出现在项目的大多数文件中。我在单个源文件中明确实例化了这些模板。我们最近切换到C++11,我正在尝试使用新的externtemplateclassMyTemplate;加快编译速度。我的第一个问题是我是否在周围使用智能指针MyTemplate正在隐式实例化模板并要求文件顶部的“外部模板..”以避免重复实例化。我的第二个问题是是否有一些替代方法来添加所有这些externtemplateclassMyTemplate;到每个源文件。为我定义的每个模板搜索智能指针的每个实例并确保我在该文件中有正

c++ - 在初始化列表中调用私有(private)函数的情况下,它是未定义的行为吗?

考虑以下代码:structCalc{Calc(constArg1&arg1,constArg2&arg2,/**/constArgN&argn):arg1(arg1),arg2(arg2),/**/argn(argn),coef1(get_coef1()),coef2(get_coef2()){}intCalc1();intCalc2();intCalc3();private:constArg1&arg1;constArg2&arg2;//...constArgN&argn;constintcoef1;//Iwanttouseconstbecauseconstintcoef2;//no

c++ - 从常规 C++ 代码调用 CUDA 代码——整理出 extern "C"

我正在尝试从单独编译的C++文件调用CUDA(主机)函数:sample.cppC++文件:extern"C"voidcuda_function(inta,intb);intmain(){//statementscuda_function(23,34);//statements}cuda.cu文件:#include__global__voidkernel(inta,intb){//statements}voidcuda_function(inta,intb){//cuda_function}构建命令:g++-csample.cppnvcc-ccuda.cunvcc-osamplesamp