摘要:流程控制首先來介紹程序的流程控制。后面跟一個代碼塊邏輯關(guān)系是當(dāng)布爾表達(dá)式為真的時候執(zhí)行代碼塊,為假的時候不執(zhí)行。
流程控制
首先來介紹程序的流程控制。
所謂的流程控制,就是在我們前面的課程中我們已經(jīng)學(xué)過了變量,數(shù)據(jù)類型,運算符,表達(dá)式,這些都是計算機(jī)編程的基本元素,但是我們程序的基本執(zhí)行單元應(yīng)該是語句,程序執(zhí)行,執(zhí)行的不是表達(dá)式,而是執(zhí)行語句。就好像我們小時候先學(xué)認(rèn)字兒,再學(xué)組詞,但最終要學(xué)造句,因為寫作文一定是一句話一句話的寫。
那么計算機(jī)程序一定會有多個語句,這個語句的執(zhí)行順序就叫做流程控制,我代碼中這么多語句先執(zhí)行誰后執(zhí)行誰,每個語句執(zhí)行幾遍,要不要執(zhí)行要不要不執(zhí)行這都叫流程控制。
順序執(zhí)行流程,我們的所有語句都放在主函數(shù)里,他一定是從主函數(shù)的第一句開始執(zhí)行,然后執(zhí)行第二句,第三句,直到把主函數(shù)中的每一句自上而下都執(zhí)行一遍的時候,程序執(zhí)行結(jié)束。比如我在主函數(shù)中寫十個打印語句,他一定是一句一句的執(zhí)行,這顯然是計算機(jī)軟件最基本的一種執(zhí)行流程,順序執(zhí)行流程。
條件分支流程而現(xiàn)在我們要介紹的是條件分支流程,條件分支流程也叫做分支結(jié)構(gòu),選擇結(jié)構(gòu),它主要解決的是有些語句我在執(zhí)行以前要先去判斷一個條件,根據(jù)這個條件來決定這條語句,或者后面的某個代碼塊執(zhí)行或者不執(zhí)行。如果說以前的順序流程是每句話執(zhí)行一遍的話,條件分支結(jié)構(gòu)是每句話執(zhí)行0-1遍,也許條件成立會執(zhí)行,條件不成立這句話就會不執(zhí)行。
說到條件分支流程,最基本的語法就是一個if語句,語法結(jié)構(gòu)如下。
if(布爾表達(dá)式){ 代碼塊 }
關(guān)鍵字if,If后面方一個圓括號 圓括號里寫什么?必須是一個布爾表達(dá)式 不可以寫整數(shù)。在C語言中布爾表達(dá)式和整數(shù)表達(dá)式是相同的,0表示假,非0值表示真,但是在java中真就是真 1就是1 真不是1 1也不是真 這是java和c的重要區(qū)別,其實也是java簡單性的體現(xiàn)。
解釋一下,例如int a = 10 int b =5本來我要比較a和b是否相等,if(a==b) 但是我寫錯了,少寫了一個等號,寫成了if(a=b)。那么在java中一個等號是賦值表達(dá)式最后的結(jié)果是5 是會報錯的,但是在C中是沒有問題的,不會報錯。這樣的錯誤不能及時發(fā)現(xiàn)就會造成一定的問題,而實際上在C的開發(fā)中這也確實是一個問題。所以java在設(shè)計的時候就補(bǔ)上了這個漏洞,其結(jié)果就是在java中if后面的圓括號中只能夠放布爾表達(dá)式。
后面跟一個代碼塊 邏輯關(guān)系是當(dāng)布爾表達(dá)式為真的時候執(zhí)行代碼塊,為假的時候不執(zhí)行。所謂代碼塊就是一個花括號,咱們也沒少見,類啊,方法啊都是一個花括號。
舉個例子,用戶輸入一個整數(shù),我們通過程序來判斷這個整數(shù)是偶數(shù)還是奇數(shù),如果是偶數(shù)就輸出偶數(shù)到控制臺,如果是奇數(shù)就什么也不輸出。代碼如下:
Scanner s = new Scanner(System.in); int n = s.nextInt(); if(n%i==0){ System.out.println("偶數(shù)"); }
這就是最基本的if語句。
那么我們的邏輯繼續(xù)變化,如果那個數(shù)字兒是偶數(shù)就打印偶數(shù)兩個字兒,如果是奇數(shù)就打印奇數(shù)兩個字兒。那么這時候需要第二個語法結(jié)構(gòu),if else。
if(布爾表達(dá)式){ 代碼塊1 }else{ 代碼塊2 }
當(dāng)布爾表達(dá)式為真的時候執(zhí)行代碼塊1,else就是否則的意思,什么叫否則,就是當(dāng)前面的那個布爾表達(dá)式為假的時候就執(zhí)行else后面的代碼塊,這就真正是條件分支了,代碼塊1和代碼塊2怎么著都會執(zhí)行一個,條件為真執(zhí)行代碼塊1,條件為假執(zhí)行代碼塊2。
根據(jù)這個邏輯我們對之前的代碼做一定的修改,如果條件為假else后面再加一個代碼塊打印奇數(shù)。
Scanner s = new Scanner(System.in); int n = s.nextInt(); if(n%i==0){ System.out.println("偶數(shù)"); }else{ System.out.println("奇數(shù)"); }
以上就是if else結(jié)構(gòu)。
下面我們看一下多重if else結(jié)構(gòu),它會有多個條件,語法結(jié)構(gòu)如下
if(條件1){ 代碼塊1 }else if(條件2){ 代碼塊2 }else if(條件3){ 代碼塊3 }else{ 代碼塊4 }
先是if條件1,當(dāng)條件1成立的時候會執(zhí)行代碼塊1,else if條件2,else代表當(dāng)條件1不滿足的時候,進(jìn)入這個else,判斷條件2,條件2成立執(zhí)行對應(yīng)代碼塊,然后執(zhí)行結(jié)束。如果進(jìn)入第三個條件,說明前兩個條件都不滿足,這時候再來判斷條件3,如果不滿足條件3,就會到最后一個else中,最后一個可以加if也可以不加,實際上就是前面所有的條件都不滿足就會到最后的else代碼塊中。
根據(jù)這個語法邏輯舉個例子,加入輸入的整數(shù)是月份,根據(jù)輸入的整數(shù)判斷是那個季節(jié),1-3是春節(jié),4-6是夏季,依次。
Scanner s = new Scanner(System.in); int n = s.nextInt(); if(n<=3){ System.out.println("春天"); }else if(n<=6){ System.out.println("夏天"); }else if(n<=9){ System.out.println("秋天"); }else{ System.out.println("冬天"); }
以上是關(guān)于if語句所有的語法結(jié)構(gòu),額外的再說一點,if語句可以根據(jù)實際的需要進(jìn)行嵌套,至于嵌套的層數(shù)沒有限制。
所有的java代碼在執(zhí)行的時候最后都會被程序最終都是一條條的指令,CPU有一個指令指示器,指向下一條要執(zhí)行的指令,CPU根據(jù)指示器的指示加載指令并且執(zhí)行。指令大部分是具體的操作和運算,在執(zhí)行這些操作時,執(zhí)行完一個操作后,指令指示器會自動指向挨著的下一個指令。
而有一種特殊的指令,稱為跳轉(zhuǎn)指令,這些指令會修改指令指示器的值,讓CPU跳到一個指定的地方執(zhí)行。跳轉(zhuǎn)有兩種,一種是條件跳轉(zhuǎn),另一種是無條件跳轉(zhuǎn)。條件跳轉(zhuǎn)檢查某個條件,滿足則進(jìn)行跳轉(zhuǎn),無條件跳轉(zhuǎn)則是直接進(jìn)行跳轉(zhuǎn)。條件分支流程在執(zhí)行的時候,if, else實際上都會轉(zhuǎn)換為這些跳轉(zhuǎn)指令。
下節(jié)預(yù)告:switch選擇結(jié)構(gòu),為什么switch后面的括號中只能夠填如byte,int等類型?
我不能保證每一個地方都是對的,但是可以保證每一句話,每一行代碼都是經(jīng)過推敲和斟酌的。希望每一篇文章背后都是自己追求純粹技術(shù)人生的態(tài)度。永遠(yuǎn)相信美好的事情即將發(fā)生。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/69298.html
摘要:系列文章系列第一篇基礎(chǔ)雜記系列第二篇插件機(jī)制雜記系列第三篇流程雜記前言本身并不難,他所完成的各種復(fù)雜炫酷的功能都依賴于他的插件機(jī)制。的插件機(jī)制依賴于一個核心的庫,。是什么是一個類似于的的庫主要是控制鉤子函數(shù)的發(fā)布與訂閱。 系列文章 Webpack系列-第一篇基礎(chǔ)雜記 Webpack系列-第二篇插件機(jī)制雜記 Webpack系列-第三篇流程雜記 前言 webpack本身并不難,他所完成...
摘要:基礎(chǔ)簡單基礎(chǔ)數(shù)據(jù)類型值得注意的是的值是,表示一個空對象指針,沒有指向任何對象。的值是,表示申明變量或?qū)ο蟮膶傩詤s未初始化。值是派生自的,所以對他們執(zhí)行相等測試會返回。字符串單引號和雙引號都可以用來表示字符串,只要前后一致即可。 目的 記憶總是會隨著時間而淡化,學(xué)習(xí)了點什么,就記錄下點什么。 做點什么,總比不做要好。 基礎(chǔ) 簡單(基礎(chǔ))數(shù)據(jù)類型 Number ...
摘要:所以也就是說在沒有的基礎(chǔ)上,執(zhí)行代碼會在串池中創(chuàng)建一個,也會在堆內(nèi)存中再出來一個。不可變性的優(yōu)點安全性字符串不可變安全性的考慮處于兩個方面,數(shù)據(jù)安全和線程安全。 摘要: String基本特性,String源碼,為什么String不可變? 前言 基于字符串String在java中的地位,關(guān)于String的常識性知識就不多做介紹了,我們先來看一段代碼 public class Test {...
摘要:前言本文為篤行日常工作記錄,爛筆頭系列。最終通過分析源碼了解到最終的確定是一個協(xié)商的過程,而不是簡單的配置生效。根據(jù)客戶端上報的和服務(wù)端自身的。如果上報的小于則設(shè)置為如果上報的大于則設(shè)置為如果介于兩則之間,則以上報的時間為準(zhǔn)。 0.前言 本文為篤行日常工作記錄,爛筆頭系列。 源碼前面,了無秘密 — by 侯杰 近期的一個C++項目里使用了Zookeeper做服務(wù)發(fā)現(xiàn),期間遇到了Sess...
摘要:前提最近通過閱讀官方文檔的事件模塊,有了一些思考和收獲,在這里記錄一下調(diào)用方法時需要手動綁定先從一段官方代碼看起代碼中的注釋提到了一句話的綁定是必須的,其實這一塊是比較容易理解的,因為這并不是的一個特殊點,而是這門語言的特性。 前提 最近通過閱讀React官方文檔的事件模塊,有了一些思考和收獲,在這里記錄一下~ 調(diào)用方法時需要手動綁定this 先從一段官方代碼看起: showImg(...
閱讀 2450·2021-10-11 10:57
閱讀 1300·2021-10-09 09:59
閱讀 2014·2019-08-30 15:53
閱讀 3228·2019-08-30 15:53
閱讀 1028·2019-08-30 15:45
閱讀 759·2019-08-30 15:44
閱讀 3470·2019-08-30 14:24
閱讀 968·2019-08-30 14:21