2601C++,模块导出分类

模块的导出分类

在导出模块中,有很多种情况,主要包括:

块导出

这好理解,就是几个导出接口用一个导出块导出,如下:

cpp 复制代码
export module demo;
export {
    //导出`多个接口`
    void test();
    class Example;
    constexpr std::string MODULE_NAME = "DEMO";
    namespace my_math {
        void add(int,int);
    }
}

指定导出

指定导出也简单,即使用导出导出指定的接口,如下:

cpp 复制代码
export module demo;
//导入但不导出
import myself_used;

//`重导出`,`聚集接口`
export import demo_math;

//部分导出:`名字空间`内函数
namespace demo_test {
    export void print(char*);
    void internal_parse();
    //不导出
}
//部分导出:类成员
export class DemoView {
public:
    void displayView(int);
//导出
    void getData(int);
//导出
private:
    void exit();
//不导出
};

分块导出

分块导出如前,看下示例:

cpp 复制代码
//`demo.cppm`
export module demo;
export import:mytest;

//子分块:`cpp`
export module demo:mytest;
export import :mytest:math;

//`管理内存`
export import :mytest:transfer;
//线程管理

注意:分块时要保证不产生循环依赖

模板导出

导出模板.看代码:

cpp 复制代码
export module templates;
export template<typename T>
T  compare(T a, T b) {
    return (a > b) ? a : b;
}

export template<typename T>
class Demo {
public:
    void Add(const T& t);
private:
    int d_ = 0;
};

export template<>
class Demo<int>
{/*如上,省略*/};
//注意:必须在`cpp`文件中显式`实例化`
export template class Demo<int>;

友元导出

如下:

cpp 复制代码
export module friend_demo;
export class friendDemo {
private:
    int d_ = 0;
private:
    friend int getData(const friendDemo&);
public:
    void test();
};

友元类类似.

继承导出

继承导出其实和继承关系不大,只是要注意虚函数的导出情况:

cpp 复制代码
export module inheritance;
//导出基类
export class Base {
protected:
    int d_ = 0;
public:
    virtual void getData();
};
//导出`继承类`
export class Derived : public Base {
public:
    void getBaseData() {
        d_ = 100;
    }
};

//`用模块继承`
import inheritance;
int main() {
    Derived d;
    d.getData();
    d.getBaseData();
    return 0;
}

枚举导出

类导出一致,更简单.

using导出

比较简单,如下:

cpp 复制代码
export module mytype;
import std;
export using VEC = std::vector<std::string>;
export typedef short int16;
export template<typename T>
using OPT = std::optional<std::reference_wrapper<T>>;

重命名导出

重命名导出也叫别名,其实也很简单,只要注意在模块中的应用方式即可,即不能直接重命名,但可封装后再次导出,如下:

cpp 复制代码
export module myself;

//导入改名模块
import old_name_lib;

//封装`新功能`名
export void export_new_func_name() {
    old_name_lib::old_func_name();
}

//使用`using,typedef`
export using ABC = old_name_lib::Demo ;
相关推荐
c++之路21 分钟前
C++信号处理
开发语言·c++·信号处理
@PHARAOH27 分钟前
WHAT - cursor cli 开发范式
前端·ai·ai编程
子兮曰1 小时前
深入 HTML-in-Canvas:当 Canvas 学会了渲染 DOM,前端图形生态要变天了
前端·javascript·canvas
ws_qy1 小时前
从大模型原理到前端 AI Coding 工程化实践
前端·ai编程
倾颜2 小时前
React 19 源码主线拆解 04:Fiber 到底是什么,React 为什么需要 Fiber?
前端·react.js·源码阅读
AI攻城狮2 小时前
国产大模型能力大比拼,社区有话说
前端
故事还在继续吗2 小时前
C++20关键特性
开发语言·c++·c++20
IT_陈寒3 小时前
Vite的public文件夹放静态资源?这坑我替你踩了
前端·人工智能·后端
涵涵(互关)3 小时前
GoView各项目文件中的相关语法2
前端·javascript·vue.js
子兮曰3 小时前
别让爬虫白嫖你的导航站了:纯免费,手把手实现加密字体防爬
前端·javascript·后端