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

How it works...

In this recipe, we explored the relationship between crates and modules. Rust supports several ways of encapsulating code into units, and the 2018 edition has made it a lot easier to do. Seasoned Rust programmers will miss the extern crate declaration(s) at the top of the files, which is nowadays only necessary in special cases. Instead, the crate's contents can be used right away in a use statement. 

In this way, the line between modules and crates is now blurred. However, modules are much simpler to create since they are part of the project and only need to be declared in the root module to be compiled. This declaration is done using the mod statement, which also supports implementation in its body—something that is used a lot in testing. Regardless of the implementation's location, using an external or internal function requires a use statement, often prefixed with crate:: to hint toward its location. 

Alternatively to simple files, a module can also be a directory that contains at least a mod.rs file. This way, large code bases can nest and structure their traits and structs accordingly.

A note on function visibility: Rust's default parameter is module visibility. Hence, a function declared and implemented in a module can only be seen from within that module. Contrary to that, the pub modifier exports the function to outside users. The same goes for properties and functions attached to a struct. 

We've successfully learned how to split our code with crates and modules. Now, let's move on to the next recipe.

主站蜘蛛池模板: 吉林省| 庆云县| 庄浪县| 湟源县| 阿巴嘎旗| 克拉玛依市| 平定县| 环江| 泰安市| 永昌县| 东丰县| 乌海市| 伊宁县| 沂南县| 射洪县| 南乐县| 湛江市| 开化县| 黄浦区| 玉田县| 侯马市| 阿荣旗| 葵青区| 资源县| 绍兴县| 娱乐| 浪卡子县| 青州市| 瑞安市| 德惠市| 青神县| 修武县| 晋城| 巴南区| 阜宁县| 华蓥市| 三都| 临沭县| 门源| 元阳县| 彰武县|