在线观看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

    文章

    579

    瀏覽量

    20517
  • 生命周期
    +關注

    關注

    0

    文章

    15

    瀏覽量

    7463
  • Rust
    +關注

    關注

    1

    文章

    228

    瀏覽量

    6610

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

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

收藏 人收藏

    評論

    相關推薦

    基于Rust語言中的生命周期

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

    AutoScaling 生命周期掛鉤功能

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

    HarmonyOS應用開發-PageAbility生命周期

    pageAbility的生命周期如下圖所示:在代碼中通過調用下列方法實現生命周期操作:onShow() :Ability由后臺不可見狀態切換到前臺可見狀態調用onShow方法,此時用戶在屏幕可以看到
    發表于 10-17 11:11

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

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

    一文讀懂Android Activity生命周期

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

    基于延長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 ?894次閱讀

    CRust學習筆記:聲明宏

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

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

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

    Vue入門Vue的生命周期

    .生命周期 4.1生命周期是什么 Vue的生命周期, 就是Vue實例從創建到銷毀的過程.
    的頭像 發表于 02-06 16:16 ?863次閱讀
    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>

    數據包的生命周期

    電子發燒友網站提供《數據包的生命周期.pdf》資料免費下載
    發表于 10-13 14:44 ?0次下載

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

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

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

    應用開發者可以根據業務場景實現data.js/data.ets中的生命周期相關接口。DataAbility生命周期接口說明見下表。
    的頭像 發表于 06-20 09:39 ?442次閱讀
    主站蜘蛛池模板: 免费看一级大片| 国产黄色高清视频| aaa特级毛片| 国产高清网站| 久久99热久久精品| 欧美一级精品高清在线观看| a毛片免费观看完整| 俺要操| 亚洲天堂免费| 毛片网此| 免费特黄视频| 中日韩毛片| 国产综合图片| 日本黄色站| 日韩成人免费一级毛片| 成人的天堂视频一区二区三区| 国产理论在线| 亚洲第8页| 成人sese| 欧美性操| 日韩免费看| 午夜看片网址| 免费观看一区二区| 老逼影院| 国产一级αv片免费观看| 亚洲成色在线综合网站| 国产乱理论片在线观看理论| aa小视频| 色综合一区| 五月天婷婷免费视频观看| 乱说欲小说又粗又长| 久久久一本| 182tv免费视视频线路一二三| 男女视频在线观看免费高清观看| 免费国产成人α片| 精品女同| 特一级黄色毛片| 免费在线成人网| 久久久久久久久女黄| 午夜免费福利片观看| 夜夜精品视频|