有没有办法将类定义(实现(拆分为多个模块单元?如果一个或多个类的方法足够大,可以放在单独的源文件中,这会很有帮助。我看到的最好的解决方案可能是在模块接口文件中声明类,并在单独的模块实现文件中定义其方法之一。但它不起作用,因为编译器看不到类声明编译模块实现文件:
//module interface unit
export module test;
export class foo
{
void f();
};
//module implementation unit
module test;
void foo::f() {} // compiler doesn't know about foo class and its methods
Module.ixx
export module foolib;
export import :foo;
export import :fooimpl;
export import :fooimpl2;
foo.ixx
export module foolib:foo;
export class foo
{
public:
void hello1();
void hello2();
};
fooimpl.ixx
export module foolib:fooimpl;
import :foo;
void foo::hello1() {}
fooimpl2.ixx
export module foolib:fooimpl2;
import :foo;
void foo::hello2() {}
非常感谢大家回答我的问题。在我最初的问题中发表的例子是有效的。正如我在给Davis-Hering的一个答案中所写的那样(感谢Davis在我的例子中更正了类方法的名称(,问题出在我的编译环境中。绝对没有必要使用模块分区来解决这个问题——它们用于不同的目的(例如,用于处理库(。
我想您询问的是模块分区。通过使每个模块单独,可以将单个模块拆分为多个源文件,但这些子模块会被识别为子模块,并自动重新组合到一个命名模块中。
分区的语法是冒号和子名称。
module foo:part1;
您可以在此处阅读更多信息:https://vector-of-bool.github.io/2019/03/10/modules-1.html
就像C++头一样,不需要将模块拆分并细分为多个文件。尽管如此,大型源文件可能会变得难以处理,因此C++模块也有办法将单个模块细分为不同的翻译单元,这些翻译单元合并在一起形成整个模块。这些细分称为分区。