在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

CRust學習筆記:生命周期-1

jf_wN0SrCdH ? 來源:coding到燈火闌珊 ? 作者: 李明 ? 2022-12-19 09:33 ? 次閱讀

本系列文章是Jon Gjengset發布的CRust of Rust系列視頻的學習筆記,CRust of Rust是一系列持續更新的Rust中級教程

在這篇文章中,我們將研究一個需要顯式注釋多個生命期的例子。我們還將討論不同字符串類型之間的一些差異,以及在自定義的trait上引入泛型。這個例子是根據給定的字符串和分隔符對字符串進行拆分。

創建一個新項目:

cargo new --lib strsplit
lib.rs中寫入如下代碼:
 1#[derive(Debug)]
 2pubstructStrSplit<'a>{
 3remainder:&'astr,
 4delimiter:&'astr,
 5}
 6
 7#[allow(dead_code)]
 8impl<'a>StrSplit<'a>{
 9pubfnnew(haystack:&'astr,delimiter:&'astr)->Self{
10Self{
11remainder:haystack,
12delimiter,
13}
14}
15}
16
17impl<'a>IteratorforStrSplit<'a>{
18typeItem=&'astr;
19
20fnnext(&mutself)->Option{
21ifletSome(next_delim)=self.remainder.find(self.delimiter){
22letuntil_remainder=&self.remainder[..next_delim];
23self.remainder=&self.remainder[next_delim+self.delimiter.len()..];
24Some(until_remainder)
25}elseifself.remainder.is_empty(){
26None
27}else{
28letrest=self.remainder;
29//為什么空字符串可以賦值給self.remainder???
30self.remainder="";
31Some(rest)
32}
33}
34}
35
36#[test]
37fnit_works(){
38lethaystack="abcde";
39letletters:Vec<_>=StrSplit::new(haystack,"").collect();
40assert_eq!(letters,vec!["a","b","c","d","e"]);
41}

StrSplit 與成員 remainder,delimiter 擁有相同的生命周期

使用fn new()方法構建的StrSplit與傳入的參數haystack,delimiter 擁有相同的生命周期

在實現Iterator trait時,迭代的結果也要與StrSplit擁有相同的生命周期,是因為要在StrSplit的成員remainder上做迭代。

在第30行,為什么空字符串可以賦值給self.remainder?這是因為self.remainder的生命周期是&'a str,空字符串的生命周期是&'static str,static的生命周期一直到程序結束。 修復Bug 這里有一個bug,添加如下測試方法:

1#[test]
2fntail(){
3lethaystack="abcd";
4letletters:Vec<_>=StrSplit::new(haystack,"").collect();
5assert_eq!(letters,vec!["a","b","c","d",""]);
6}
執行cargo test:
running 2 tests
test str_split_1::it_works ... ok
test str_split_1::tail ... FAILED
我們將struct StrSplit的成員remainder定義為Option<&'a str>類型來修復這個bug:
 1/**
 2*StrSplit與成員remainder,delimiter擁有相同的生命周期
 3*/
 4#[derive(Debug)]
 5pubstructStrSplit<'a>{
 6//使用Option
 7remainder:Option<&'a?str>,
 8delimiter:&'astr,
 9}
10
11#[allow(dead_code)]
12impl<'a>StrSplit<'a>{
13/**
14*新構建的StrSplit與傳入的參數haystack,delimiter擁有相同的生命周期
15*/
16pubfnnew(haystack:&'astr,delimiter:&'astr)->Self{
17Self{
18remainder:Some(haystack),
19delimiter,
20}
21}
22}
23
24impl<'a>IteratorforStrSplit<'a>{
25//迭代的結果也要與StrSplit擁有相同的生命周期,是因為要在StrSplit的成員remainder上做迭代。
26typeItem=&'astr;
27
28fnnext(&mutself)->Option{
29//這里為什么用Some(refmutremainder),而不用Some(&mutrefmainder)???
30ifletSome(refmutremainder)=self.remainder{
31ifletSome(next_delim)=remainder.find(self.delimiter){
32letuntil_remainder=&remainder[..next_delim];
33*remainder=&remainder[next_delim+self.delimiter.len()..];
34Some(until_remainder)
35}else{
36self.remainder.take()
37}
38}else{
39None
40}
41}
42}
43
44#[test]
45fnit_works(){
46lethaystack="abcde";
47letletters:Vec<_>=StrSplit::new(haystack,"").collect();
48assert_eq!(letters,vec!["a","b","c","d","e"]);
49}
50
51#[test]
52fntail(){
53lethaystack="abcd";
54letletters:Vec<_>=StrSplit::new(haystack,"").collect();
55assert_eq!(letters,vec!["a","b","c","d",""]);
56}
執行cargo test,測試通過:
running 2 tests
test str_split_2::tail ... ok
test str_split_2::it_works ... ok
在上面代碼的第30行,為什么用Some(ref mut remainder),而不是用Some(&mut refmainder)?這是因為在進行Some(&mut remainder)=self.remainder模式匹配時,remainder會被自動解引用成str類型,而不是可變的&str類型。 另一種寫法
 1impl<'a>IteratorforStrSplit<'a>{
 2//迭代的結果也要與StrSplit擁有相同的生命周期,是因為要在StrSplit的成員remainder上做迭代。
 3typeItem=&'astr;
 4
 5fnnext(&mutself)->Option{
 6//為什么不可以這么寫???
 7letremainder=&mutself.remainder?;
 8ifletSome(next_delim)=remainder.find(self.delimiter){
 9letuntil_remainder=&remainder[..next_delim];
10*remainder=&remainder[next_delim+self.delimiter.len()..];
11Some(until_remainder)
12}else{
13self.remainder.take()
14}
15}
16}
17

在迭代器的next方法里嘗試換一種寫法,編譯器檢查通過,但是執行測試不通過。也就是上面代碼的第7行,為什么不可以這么寫?

self.remainder是Option<&'a str>類型,這里的泛型是引用。所以在執行unwrap(),expect()或?時,會將Option里的引用Copy一份出來賦值給remainder,然后在這個新的remainder上作可變引用,而self.remainder沒有任何變化。

我們可以使用Option的as_mut()方法,因為它返回的是Option<&mut T>:

1fnnext(&mutself)->Option{
2//為什么這么寫不可以???
3//letremainder=&mutself.remainder?;
4
5letremainder=self.remainder.as_mut()?;
6......
7}

得到了一個self.remainder的可變引用,因此測試通過。

在下一篇文章中,我們通過更多的例子來繼續學習Rust的生命周期。

審核編輯:湯梓紅

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 字符串
    +關注

    關注

    1

    文章

    589

    瀏覽量

    21149
  • 生命周期
    +關注

    關注

    0

    文章

    16

    瀏覽量

    7502
  • Rust
    +關注

    關注

    1

    文章

    233

    瀏覽量

    6975

原文標題:CRust學習筆記:生命周期-1

文章出處:【微信號:Rust語言中文社區,微信公眾號:Rust語言中文社區】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦
    熱點推薦

    基于Rust語言中的生命周期

    Rust是一門系統級編程語言具備高效、安和并發等特,而生命周期是這門語言中比較重要的概念之一。在這篇教程中,我們會了解什么是命周期、為什么需要生命周期、如何使用生命周期,同時我們依然會
    的頭像 發表于 09-19 17:03 ?1103次閱讀

    KaihongOS操作系統:頁面的生命周期介紹

    頁面的生命周期 在KaihongOS中,學習頁面的生命周期前需要先了解自定義組件。 1. 自定義組件(Component) 自定義組件是通過@Component裝飾的UI單元,可
    發表于 04-25 08:18

    ServiceAbility的生命周期介紹

    ServiceAbility的生命周期 開發者可以根據業務場景重寫生命周期相關接口。ServiceAbility生命周期接口說明見下表。 表1 ServiceAbility
    發表于 05-28 08:22

    AutoScaling 生命周期掛鉤功能

    摘要: AutoScaling 伸縮組實例管理功能全面升級,新上線生命周期掛鉤(LifecycleHook)功能,方便用戶更加靈活地管理伸縮組內實例。使用生命周期掛鉤可以在伸縮組發生伸縮活動時將伸縮
    發表于 06-27 17:13

    在S32G2 RM中有“生命周期”,生命周期的完整含義是什么?

    在S32G2 RM中,有“生命周期”。生命周期的完整含義是什么,我們應該如何使用它?
    發表于 04-23 10:37

    一文讀懂Android Activity生命周期

    正常情況下Activity的生命周期: Activity的生命周期大概可以歸為三部分 整個的生命周期:onCreate()可以設置所有的“全局”狀態, onDestory()可以釋放所有的資源 可見
    發表于 05-30 01:03 ?1709次閱讀

    基于延長WSN生命周期的LEACH算法的改進

    基于延長WSN生命周期的LEACH算法的改進(開關電源技術與設計pdf百度云)-基于延長WSN生命周期的LEACH算法的改進? ? ? ? ? ? ? ? ? ??
    發表于 09-15 11:17 ?14次下載
    基于延長WSN<b class='flag-5'>生命周期</b>的LEACH算法的改進

    CRust學習筆記生命周期-2

    本系列文章是Jon Gjengset發布的CRust of Rust系列視頻的學習筆記CRust of Rust是一系列持續更新的Rust中級教程。
    的頭像 發表于 12-19 09:34 ?1185次閱讀

    CRust學習筆記:聲明宏

    本系列文章是Jon Gjengset發布的CRust of Rust系列視頻的學習筆記CRust of Rust是一系列持續更新的Rust中級教程。
    的頭像 發表于 01-06 14:37 ?1052次閱讀

    CRust學習筆記:智能指針和內部可變性

    本系列文章是Jon Gjengset發布的CRust of Rust系列視頻的學習筆記CRust of Rust是一系列持續更新的Rust中級教程。
    的頭像 發表于 01-29 14:58 ?984次閱讀

    Vue入門Vue的生命周期

    .生命周期 4.1生命周期是什么 Vue的生命周期, 就是Vue實例從創建到銷毀的過程.
    的頭像 發表于 02-06 16:16 ?1028次閱讀
    Vue入門Vue的<b class='flag-5'>生命周期</b>

    編譯器的標準生命周期

    編譯器的標準生命周期
    發表于 03-14 19:06 ?0次下載
    編譯器的標準<b class='flag-5'>生命周期</b>

    編譯器的標準生命周期

    編譯器的標準生命周期
    發表于 07-05 19:32 ?1次下載
    編譯器的標準<b class='flag-5'>生命周期</b>

    鴻蒙開發:【PageAbility的生命周期

    PageAbility生命周期是PageAbility被調度到INACTIVE、ACTIVE、BACKGROUND等各個狀態的統稱。PageAbility生命周期流轉及狀態說明見如下圖1、表1
    的頭像 發表于 06-17 10:05 ?953次閱讀
    鴻蒙開發:【PageAbility的<b class='flag-5'>生命周期</b>】

    鴻蒙開發組件:DataAbility的生命周期

    應用開發者可以根據業務場景實現data.js/data.ets中的生命周期相關接口。DataAbility生命周期接口說明見下表。
    的頭像 發表于 06-20 09:39 ?682次閱讀
    主站蜘蛛池模板: 五月四房婷婷 | a级午夜毛片免费一区二区 a看片 | 91精品久久久久含羞草 | 成人午夜小视频手机在线看 | 久久国内 | 九九99久久精品影视 | 天天爽夜夜春 | 久久精品国产99精品国产2021 | 四虎最新紧急入口 | 欧美三级大片在线观看 | 久久综合图片 | 久久草在线观看 | 精品国产免费久久久久久婷婷 | 女女色综合影院 | 国产免费一区二区三区 | 丝袜美女被c | 日韩欧美一区二区三区不卡视频 | 狠狠色噜噜狠狠狠狠黑人 | 免费毛片大全 | 美女国产在线观看免费观看 | 三级视频欧美 | 毛片高清一区二区三区 | 一级大片视频 | 老师叫我下面含着精子去上课 | 不卡视频免费在线观看 | 在线中文字幕第一页 | 丁香激情六月天 | 久久久久久夜精品精品免费啦 | 亚洲三级毛片 | 日韩电影中文字幕 | 模特精品视频一区 | 四虎影院精品在线观看 | 欧美成人69 | 五月天男人的天堂 | 亚洲高清视频一区 | 天天色视频 | 看逼网址| 国产自产视频在线观看香蕉 | 国产色婷婷 | 国产成人免费无庶挡视频 | 欧美色婷婷天堂网站 |