官术网_书友最值得收藏!

Modules, imports, and use statements

Languages often provide a way to split large code bases into multiple files to manage complexity. Java follows the convention of a single public class per .java file, while C++ provides us with header files and include statements. Rust is no different and provides us with modules. Modules are a way to namespace or organize code in a Rust program. To allow flexibility in organizing our code, there are multiple ways to create modules. Modules are a complex topic to understand and to make it brief for this section, we'll highlight only the important aspects about using them. Modules are covered in detail in Chapter 2, Managing Projects with Cargo. The following are the key takeaways about modules in Rust:

  • Every Rust program needs to have a root module. In executables, it is usually the main.rs file, and for libraries, it is lib.rs.
  • Modules can be declared within other modules or can be organized as files and directories.
  • To let the compiler know about our module, we need to declare it using the mod keyword, as in mod my_module;, in our root module.
  • To use any of the items within the module, we need to use the use keyword, along with the name of the module. This is known as bringing the item into scope.
  • Items defined within modules are private by default, and you need to use the pub keyword to expose them to their consumers.

That was modules in brief. Some of the advanced aspects of modules are also covered in Chapter 7, Advanced Concepts. Next, let's look at the commonly used collection types that are available in the standard library.

主站蜘蛛池模板: 邹平县| 富阳市| 邹城市| 临桂县| 西青区| 淮滨县| 双柏县| 高雄县| 绥滨县| 安丘市| 渑池县| 东山县| 新干县| 荆州市| 赤壁市| 光山县| 抚州市| 简阳市| 东源县| 阜南县| 静海县| 临洮县| 衡东县| 临泉县| 科尔| 安化县| 兰西县| 盐池县| 措勤县| 昌乐县| 姚安县| 包头市| 乌拉特后旗| 琼中| 兖州市| 治多县| 长丰县| 渝北区| 顺义区| 华安县| 桃源县|