国产乱子伦高清露脸对白-国产精品欧美久久久久天天影视-国产91视频一区-亚洲欧美日产综合在线网-黄视频网站在线看-国产欧美亚洲精品第1页-亚洲www在线-大学生女人三级在线播放-日本在线视频www鲁啊鲁-国产成人精品一区二区仙踪林-69精品欧美一区二区三区-成人欧美亚洲-日本污污网站-中国妞xxxhd露脸偷拍视频-国产精品aⅴ在线观看-精品中文字幕在线

極客小將

您現在的位置是:首頁 » scratch編程資訊

資訊內容

一把雙刃劍:Scratch數據類型的隱式轉換

極客小將2020-11-17-
筆者曾經也寫過一篇關于數據類型的文章:《從數據類型到計算思維》,對
筆者曾經也寫過一篇關于數據類型的文章:《從數據類型到計算思維》,對upload/article/images/2020-11-17/616cacc510f35ef64e8d7a3bdafc3b75.jpg這個積木在數據類型不同的情況下的執行邏輯做了一個簡單匯總,并總結了一些規律。事實上,Scratch是一門弱數據類型的語言,不同于強類型語言在遇到函數引數類型和實際調用類型不匹配的情況經常會直接出錯或者編譯失敗,弱數據類型的語言會進行隱式轉換,有時會產生難以意料的結果。本文將在前篇《從數據類型到計算思維》的基礎上對Scratch數據類型隱式轉換問題進行補充、完善。

01

在前篇從數據類型到計算思維》中,通過幾個簡單的測試,總結了幾條upload/article/images/2020-11-17/616cacc510f35ef64e8d7a3bdafc3b75.jpg積木在不同數據類型情況下執行邏輯的規律。

源碼佐證:

_setCostume (target, requestedCostume, optZeroIndex) {if (typeof requestedCostume === 'number') {// Numbers should be treated as costume indices, alwaystarget.setCostume(optZeroIndex ? requestedCostume : requestedCostume - 1);} else {// Strings should be treated as costume names, where possibleconst costumeIndex = target.getCostumeIndexByName(requestedCostume.toString());

數字類型的參數被當做造型編號來執行,字符類型的參數被當做造型名稱來執行(前提是有對應的造型名稱時)

if (costumeIndex !== -1) {target.setCostume(costumeIndex);} else if (requestedCostume === 'next costume') {target.setCostume(target.currentCostume + 1);} else if (requestedCostume === 'previous costume') {target.setCostume(target.currentCostume - 1);// Try to cast the string to a number (and treat it as a costume index)// Pure whitespace should not be treated as a number// Note: isNaN will cast the string to a number before checking if it's NaN} else if (!(isNaN(requestedCostume) || Cast.isWhiteSpace(requestedCostume))) {target.setCostume(optZeroIndex ? Number(requestedCostume) : Number(requestedCostume) - 1);}

字符類型的參數會被優先“嘗試”轉換為數字類型,并作為造型編號執行。

upload/article/images/2020-11-17/616cacc510f35ef64e8d7a3bdafc3b75.jpg只是諸多會對數據類型進行自動轉換的積木之一,也是在使用時最容易出BUG、最具代表性的積木。幾乎所有積木都會對數據類型進行自動轉換,有的甚至對輸入的數據類型做了限制,如,無法直接在upload/article/images/2020-11-17/2c4fb20b280a4bcc061c1b8b01cf066a.jpg積木中輸入字符。

有的積木保是有自己的關鍵詞的,如upload/article/images/2020-11-17/616cacc510f35ef64e8d7a3bdafc3b75.jpg,可以通過給變量賦值“previous costume”而實現“上一個造型”的效果。還有在《Scratch3.0的十宗罪》中提到的在Sc3.0中訪問列表末項、隨機項的方法。upload/article/images/2020-11-17/9b4dd5036c334b163990dfffda5c1f5b.jpg本身是允許輸入數字類型的。但是通過變量賦值、或是在中文輸入法下拼寫完整單詞直接敲入,可以強行輸入字符類型的關鍵詞,如“all”、“any”、“last”、“random”,實現直接訪問指定項的效果。 if (typeof index !== 'number') {if (index === 'all') {return acceptAll ? Cast.LIST_ALL : Cast.LIST_INVALID;}if (index === 'last') {if (length > 0) {return length;}return Cast.LIST_INVALID;} else if (index === 'random' || index === 'any') {if (length > 0) {return 1 + Math.floor(Math.random() * length);}return Cast.LIST_INVALID;}}

02

轉數字類型失敗

然而并不是所有積木都“幸運”地擁有關鍵詞的。那些沒有關鍵詞的、或者是參數不等于關鍵詞的,Scratch會如何處理呢? static toNumber (value) {// If value is already a number we don't need to coerce it with// Number().if (typeof value === 'number') {// Scratch treats NaN as 0, when needed as a number.// E.g., 0 + NaN -> 0.if (Number.isNaN(value)) {return 0;}return value;無法被轉換為數字類型的參數(即NaN),將會被轉換為0。有無數多的BUG都是因為這個原因而產生的,比如角色沒有移動到預期位置,卻總是在舞臺中央停滯不前。upload/article/images/2020-11-17/9aa34fdfc3d3b5565eb1ebe1f77aa7a4.jpg很有可能就是這兩個變量中的參數被轉為0了。這個例子更多的會發生在訪問列表的特定項時,索引越界,返回空字符,空字符被轉換為0,像這樣upload/article/images/2020-11-17/87efa9489ecbb67f69f157c397f44237.jpg。列表的問題足以新開一篇文章來探討,在此就不費過多筆墨了。

03

布爾值的規則

其實這個小節的主題才是筆者動筆寫這篇文章的主要動機。它來源于一位群友的問題。一個非常經典的問題。

upload/article/images/2020-11-17/1705ecee739e1f0eabded745650cb636.jpg

比較運算符的連續嵌套使用

初學者會這樣寫腳本的原因是將數學中的習慣帶到編程里來了(別問筆者是怎么知道的,問就是筆者也犯過相同的錯誤。。)乍一看好像沒有什么問題。但是要知道,程序是一步一步執行的,像這樣嵌套關系的積木,也是先執行上層的,再執行下層的(相當于數學中的括號)。3>2的結果是true(不打引號以區分字符類型),再比較true和1的大小。到這一步,不論接下去的結果如何,都應該能發現,和數學中連續比較的的3>2>1不一樣,這么寫是錯的,是肯定無法得到預期結果的。本著 Scratch 格物堂的“格物”精神,繼續往下看。true和1怎么比大小?這還不簡單嗎?《Scratch 3.0的大小比較是如何進行的》一文中已經說得很清楚了,字符類型的數據在參與比較運算時,比較的是ASCII碼或者說是Unicode碼。而數字0的十進制編號是48,A是65,a是97。就算Scratch不區分大小寫,二十六個字母怎么的也是排在數字后面,字母是肯定大于數字的,“true”>1肯定是true。

upload/article/images/2020-11-17/b929132bf4b3cc3818a20243d8a9da7f.jpg

“true”>1

看似沒毛病

但是一運行整個腳本。。。

upload/article/images/2020-11-17/c83546e39ccf3ff1d2889ba6b69cec56.jpg

于是開始倒推哪個環節出了問題。

用《Debug in Scratch —— Part 1》中提到的“氣泡輸出法”進行排查:

upload/article/images/2020-11-17/db8e59d8548472e1583e8f747f09e082.jpg

曾經引以為傲的“氣泡輸出法”

upload/article/images/2020-11-17/778463de7f8ba6d807e60c962ba546ee.jpg

說“true”

還是沒問題

細心的讀者可能會發現,上文中的true,是什么時候被打上引號的?true在參與比較運算時,真的是“true”嗎?我們想當然地以為true被轉換成了字符類型。但是不是字符類型還能是什么?NaN,難道被轉成了0嗎?0>1的確是false沒錯,好像說通了。但是換幾個用例再次進行測試,發現結果又不太一樣。篇幅有限,不再進行引導。直接上測試印證猜測

測試1:

upload/article/images/2020-11-17/b7e06d1f684307bead7d056bd4aa8c6c.jpg

布爾類型(true)參數參與算術運算(+空字符)

測試2:

upload/article/images/2020-11-17/bc87633b9dcfb5ce2826caa649628583.jpg

布爾類型(false)參數參與算術運算(+空字符)

這兩個小測試足以證明,

true被轉換為數字類型時,會被轉換為1;false在被轉換為數字類型時,會被轉換為0.

在上文中的比較運算符的連續嵌套使用示例中,第二次其實是在比較1>1,結果自然是false了。至于為什么“氣泡輸出法”會失效,這是因為upload/article/images/2020-11-17/9d01d293ccb1dc07b54315f8e0d12b6e.jpg這類積木會將參數轉換為字符類型。


04

實例

也許使用布爾值參與比較運算的確實用價值不高,一般在案例實戰中不會這么用,僅僅需要了解其原因即可。但是筆者的的確確見過一種使用布爾值參與算術運算,巧妙利用數據類型隱式轉換這個特點的案例。下面和讀者朋友們分享一下。
一起盜竊案,有4名嫌疑人。這4人只有一名小偷。已知,這4名嫌疑人中,有且僅有1人在說謊。
首先用腳本把4個嫌疑人的供詞用邏輯表達式表示出來:

upload/article/images/2020-11-17/4f7c328046911755aeb7062f13a64a50.jpg

1號:“不是我。”

upload/article/images/2020-11-17/9bb8019ad4f9935df8940362126f81f8.jpg

2號:“小偷是3號。”

upload/article/images/2020-11-17/e442eca09ea2a9c5aece2d876ddfb3e5.jpg

3號:“小偷是4號。”

upload/article/images/2020-11-17/86c1eeee9eda21550a560125aa6c9272.jpg

4號:“3號在說謊”


接著根據條件“4個嫌疑人中有且僅有1人在說謊”,可以推導出結論:以上4個邏輯表達式中,有3個是成立的,有1個是不成立的。再結合上文中get的新技能:布爾值在被轉換為數字類型時,true會被轉換為1,false會被轉換為0,不難得出以下結論:

upload/article/images/2020-11-17/965e80d91f833682a876abec6de72aea.jpg

4名嫌疑人中,有且僅有1人在說謊


最后要做的就只有一件事了:遍歷,從小偷=1開始,逐個驗證即可。篇幅有限,具體步驟就沒必要再細說了。
案例來源:《Scratch趣味編程進階》?作者:謝聲濤


05

總結

如果用哲學中的矛盾觀來分析數據類型的隱式轉換這個問題的話,積木本身的種類、本身的參數類型是主要矛盾,居于主導地位,它決定數據將會被轉換成什么類型;而參數的數據類型則是次要矛盾,位居從屬地位。如果積木本身的參數類型與實際參數類型不匹配,則會優先嘗試將其轉化為本身的參數類型,同時兼顧地“考慮”一下參數本身的“想法”,看看它是否“愿意”被轉換為那種類型,若“不愿意”,則另做打算(比如轉成0或者再比如upload/article/images/2020-11-17/616cacc510f35ef64e8d7a3bdafc3b75.jpg的復雜轉化邏輯)。
Scratch數據類型的隱式轉換這個問題,筆者秉持辯證的觀點來看待。首先這樣無疑對新手來說無疑是十分友好的,易上手。否則動不動地給你報個錯,如果對Scratch的數據類型不夠了解的話,幾乎解決不了。那么現有的教學知識體系中又要多一塊龐大卻又對邏輯思維能力的提升不大且極為枯燥的內容了,這絕對是在“勸退”初學者。另一個優點就是,只要你的想象力足夠豐富,就能利用這個特點做出精妙的案例(前提是你要清楚地知道自己在做什么)。

但是隱式轉換帶來的負面影響也同樣地明顯。相比強類型的語言,Scratch在數據類型這方面來說顯得不夠嚴謹。其次,和其他弱類型語言一樣,隱式轉換總是被打上“它們的存在將導致錯誤的發生”的標簽。一如上文中的3>2>1。Scratch數據類型隱式轉換所造成的BUG數不勝數,細分下去種類繁多。并且就像他的名字一樣,十分隱蔽,極難排查,即使像上文中那樣運用一般的debug方法,也很有可能會因為再次發生隱式轉換而失效。

聲明:本文章由網友投稿作為教育分享用途,如有侵權原作者可通過郵件及時和我們聯系刪除

預約試聽課

已有385人預約都是免費的,你也試試吧...

国产乱子伦高清露脸对白-国产精品欧美久久久久天天影视-国产91视频一区-亚洲欧美日产综合在线网-黄视频网站在线看-国产欧美亚洲精品第1页-亚洲www在线-大学生女人三级在线播放-日本在线视频www鲁啊鲁-国产成人精品一区二区仙踪林-69精品欧美一区二区三区-成人欧美亚洲-日本污污网站-中国妞xxxhd露脸偷拍视频-国产精品aⅴ在线观看-精品中文字幕在线

        手机av在线网站| 91蝌蚪视频在线| 艳母动漫在线免费观看| 国产熟人av一二三区| 亚洲不卡中文字幕无码| 国产精品无码av在线播放| 日本一本中文字幕| 一卡二卡三卡视频| 免费看黄在线看| 国产中文字幕视频在线观看| 国产综合av在线| www.四虎成人| 国产一级片黄色| 日韩一级免费片| 色姑娘综合天天| 丁香六月激情婷婷| 久久精品免费一区二区| 中文字幕亚洲乱码| 免费看啪啪网站| av免费看网址| 黄www在线观看| 中文字幕一区二区在线观看视频| 无码毛片aaa在线| 中文字幕无码精品亚洲资源网久久| 国产日产欧美视频| 91视频福利网| 成人一级片网站| 天堂av8在线| 可以在线看的av网站| 日本人69视频| 国产av熟女一区二区三区 | 国产真人无码作爱视频免费| 日本中文字幕二区| 无码专区aaaaaa免费视频| 精品久久久久久无码国产| 青少年xxxxx性开放hg| 97在线免费公开视频| 国产免费一区二区三区四在线播放 | 伊人色在线观看| 可以免费看的黄色网址| 欧美日韩大尺度| 欧美亚洲黄色片| 久久人人爽av| 97国产在线播放| 性久久久久久久久久久久久久| 日韩a在线播放| 日本久久久网站| 夜夜爽久久精品91| 久久撸在线视频| 男人天堂网视频| 国产精品999视频| 成人污网站在线观看| 日本国产一级片| 天堂视频免费看| 国产免费成人在线| 国产婷婷一区二区三区| 国产视频在线观看网站| 青青草免费在线视频观看| 国内国产精品天干天干| 成人一区二区三| 日韩a在线播放| 2022亚洲天堂| 国产裸体舞一区二区三区| 国产黄色一级网站| 水蜜桃色314在线观看| 国产午夜大地久久| 北条麻妃69av| 久草精品在线播放| wwwwww.色| 欧美日韩一区二区三区69堂| 国产wwwxx| 国产美女视频免费看| 香蕉视频在线网址| 穿情趣内衣被c到高潮视频| 男人添女人下部视频免费| 日韩免费在线观看av| 久久国产精品视频在线观看| 日韩国产欧美亚洲| 乱子伦视频在线看| jizzzz日本| 久久精品国产精品亚洲精品色| 男人j进女人j| 国产肥臀一区二区福利视频| 日韩福利视频在线| 亚洲 欧洲 日韩| 人人干视频在线| 亚洲国产精品三区| 成人在线观看毛片| 日韩精品 欧美| 国产精品拍拍拍| 热久久最新网址| 国产精品-区区久久久狼| 亚洲欧美天堂在线| 国产女大学生av| 精品国产乱码久久久久久1区二区| 久久av秘一区二区三区| 高清在线观看免费| 亚洲涩涩在线观看| 久久国产精品网| 天堂在线精品视频| 少妇人妻在线视频| 中文字幕视频三区| 免费日韩视频在线观看| 国产传媒免费观看| 男人操女人逼免费视频| 老汉色影院首页| 手机在线看福利| 日韩国产欧美亚洲| 日本a级片在线观看| 欧美三级理论片| 欧美在线观看成人| 97超碰在线视| 影音先锋成人资源网站| 久久精品影视大全| www国产精品内射老熟女| 超碰在线免费观看97| 无限资源日本好片| 日韩 欧美 高清| 国产免费一区二区三区视频| 菠萝蜜视频在线观看入口| 亚洲一级片av| 欧美性受xxxxxx黑人xyx性爽| 97在线播放视频| 六月丁香婷婷激情| 欧美色图色综合| 国产成人a亚洲精v品无码| 日韩精品在线视频免费观看| 亚洲国产一二三精品无码| 婷婷视频在线播放| 黄色www在线观看| 国产盗摄视频在线观看| 久久久久久久久网| 真人做人试看60分钟免费| 女人床在线观看| 99在线观看视频免费| 搞av.com| 日本成年人网址| 国产一级不卡毛片| 五月婷婷六月丁香激情| 伊人五月天婷婷| 毛片av在线播放| 91av资源网| 性猛交ⅹ×××乱大交| 天天操狠狠操夜夜操| 国产精品亚洲天堂| 精品少妇在线视频| 欧美日韩二三区| 一级在线免费视频| 久久艹这里只有精品| 日韩欧美精品免费| 啊啊啊一区二区| 亚洲欧美自拍另类日韩| 午夜激情影院在线观看| 蜜臀av色欲a片无码精品一区 | 毛毛毛毛毛毛毛片123| 久久久久福利视频| 欧美一级片中文字幕| 久久人人爽av| 你懂的av在线| 在线免费观看av网| 无码粉嫩虎白一线天在线观看 | 午夜久久福利视频| 欧美日韩dvd| 亚洲这里只有精品| 狠狠精品干练久久久无码中文字幕| 黄色影院一级片| 99热一区二区三区| 黄色一级一级片| 人体内射精一区二区三区| 99国产精品久久久久久| 97国产精东麻豆人妻电影| 日韩欧美亚洲另类| 成人在线免费在线观看| 久久久久久久久网| 狠狠干狠狠操视频| 超碰网在线观看| 国产午夜大地久久| 黄色小视频大全| 日韩成人精品视频在线观看| 能在线观看的av| av免费看网址| 99在线观看视频免费| 在线免费黄色网| 第四色婷婷基地| 孩娇小videos精品| 亚欧在线免费观看| 日日摸日日碰夜夜爽av| 免费网站永久免费观看| 中国老女人av| 国产又粗又大又爽的视频| 国产免费999| 超碰在线公开97| 欧美精品aaaa| 激情 小说 亚洲 图片: 伦| 九色porny91| 亚洲这里只有精品| 午夜精品中文字幕| 四虎成人在线播放| 精产国品一二三区| 强开小嫩苞一区二区三区网站|