java基礎之循環

????????Java中有三種主要的循環結構:

  • while?循環
  • do…while?循環
  • for?循環

1、while循環

1.1、結構

while( 布爾表達式 ) { //循環內容 }

?1.2、實例

public class TestWhile {public static void main(String[] args) {int x= 1;while (x<=10){System.out.println("value of x:" + x);x++;}}
}結果:
value of x:1
value of x:2
value of x:3
value of x:4
value of x:5
value of x:6
value of x:7
value of x:8
value of x:9
value of x:10

2、do…while 循環

2.1、結構

do { //代碼語句 }while(布爾表達式);

?2.2、實例

public class TestDoWhile {public static void main(String[] args) {int x= 1;do {System.out.println("value of x:" + x);x++;}while (x<=10);}
}
結果:
value of x:1
value of x:2
value of x:3
value of x:4
value of x:5
value of x:6
value of x:7
value of x:8
value of x:9
value of x:10

3、for循環

3.1、結構

for(初始化; 布爾表達式; 更新) {
? ? //代碼語句
}

3.2、實例

public class TestFor {public static void main(String[] args) {for (int i = 0; i <= 10; i++) {System.out.println("value of x:"+ i);}}
}
執行結果:
value of x:0
value of x:1
value of x:2
value of x:3
value of x:4
value of x:5
value of x:6
value of x:7
value of x:8
value of x:9
value of x:10

4、增強 for 循環

????????JDK 1.5 引進了一種新的循環類型,被稱為 For-Each 循環或者加強型循環,它能在不使用下標的情況下遍歷數組。

4.1、結構

for(type element: array)
{
? ? System.out.println(element);
}

4.2、實例

public class TestForStrong {public static void main(String[] args) {int[] number = {1,2,3,4,5};for (int x : number){System.out.println("value of x:"+x);}}
}
執行結果:
value of x:1
value of x:2
value of x:3
value of x:4
value of x:5

5、?Iterator(迭代器)

5.1、結構

  • Java迭代器(Iterator)是 Java 集合框架中的一種機制,是一種用于遍歷集合(如列表、集合和映射等)的接口。
  • 它提供了一種統一的方式來訪問集合中的元素,而不需要了解底層集合的具體實現細節。
  • Java Iterator(迭代器)不是一個集合,它是一種用于訪問集合的方法,可用于迭代ArrayList和HashSet等集合。
  • Iterator 是 Java 迭代器最簡單的實現,ListIterator 是 Collection API 中的接口, 它擴展了 Iterator 接口。

5.2、方法

常用的是以下三個:

  • next()?- 返回迭代器的下一個元素,并將迭代器的指針移到下一個位置。

  • hasNext()?- 用于判斷集合中是否還有下一個元素可以訪問。

  • remove()?- 從集合中刪除迭代器最后訪問的元素(可選操作)。

5.3、實例

public class TestIterator {public static void main(String[] args) {// 創建集合List<String> list = new ArrayList<String>();list.add("張三");list.add("李四");list.add("王五");System.out.println("list:"+list);// 獲取迭代器Iterator<String> it = list.iterator();// 輸出集合while (it.hasNext()){String next = it.next();System.out.println(next);//刪除元素if (next.equals("張三")){it.remove();}}System.out.println("list:"+list);}
}
執行結果:
list:[張三, 李四, 王五]
張三
李四
王五
list:[李四, 王五]

?6、循環控制

6.1、break

break 主要用在循環語句或者 switch 語句中,用來跳出整個語句塊。

break 跳出最里層的循環,并且繼續執行該循環下面的語句。

public class TestFor {public static void main(String[] args) {for (int i = 0; i <= 10; i++) {System.out.println("value of x:"+ i);if (i  == 5){break;}}}
}
執行結果:
value of x:0
value of x:1
value of x:2
value of x:3
value of x:4
value of x:5

6.2、continue

  • continue 適用于任何循環控制結構中。作用是讓程序立刻跳轉到下一次循環的迭代。
  • 在 for 循環中,continue 語句使程序立即跳轉到更新語句。
  • 在 while 或者 do…while 循環中,程序立即跳轉到布爾表達式的判斷語句。
public class TestFor {public static void main(String[] args) {for (int i = 0; i <= 10; i++) {if (i  == 5){continue;}System.out.println("value of x:"+ i);}}
}
執行結果:
value of x:0
value of x:1
value of x:2
value of x:3
value of x:4
value of x:6
value of x:7
value of x:8
value of x:9
value of x:10

6.3、return

????????return并不是專門用來結束循環的關鍵字,它可以用來結束一個方法或循環。當一個方法執行到return語句時,該方法就會被結束。與break和continue不同的是,return是直接結束整個方法,不管這個return處在多少層的循環之內。

public class TestFor {public static void main(String[] args) {for (int i = 0; i <= 10; i++) {if (i  == 5){return;}System.out.println("value of x:"+ i);}}
}
執行結果:
value of x:0
value of x:1
value of x:2
value of x:3
value of x:4

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/206818.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/206818.shtml
英文地址,請注明出處:http://en.pswp.cn/news/206818.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

組個最小數

給定數字0-9各若干個。你可以以任意順序排列這些數字&#xff0c;但必須全部使用。目標是使得最后得到的數盡可能小&#xff08;注意0不能做首位&#xff09;。例如&#xff1a;給定兩個0&#xff0c;兩個1&#xff0c;三個5&#xff0c;一個8&#xff0c;我們得到的最小的數就…

f2fs解析(一)f2fs如何解決wandering tree

wandering tree問題是log-structured 文件系統&#xff08;LFS&#xff09; 特有的一個問題&#xff0c;因為LFS的臟數據是追加更新的&#xff0c;所以如果一個數據塊變臟了&#xff0c;那么那個數據塊的直接索引塊、間接索引塊都會變臟&#xff08;因為索引的地址變臟&#xf…

阿里云通義千問720億參數模型開源,適配企業級、科研級高性能應用

12月1日&#xff0c;阿里云舉辦通義千問發布會&#xff0c;開源通義千問720億參數模型Qwen-72B。Qwen-72B在10個權威基準測評創下開源模型最優成績&#xff0c;成為業界最強開源大模型&#xff0c;性能超越開源標桿Llama 2-70B和大部分商用閉源模型。未來&#xff0c;企業級、科…

Spring Cloud + Vue前后端分離-第2章 使用Maven搭建SpringCloud項目

Spring Cloud Vue前后端分離-第2章 使用Maven搭建SpringCloud項目 Maven兩大核心功能&#xff1a; 依賴管理&#xff08;Jar包管理&#xff09; 構建項目&#xff08;項目打包&#xff09; 使用Eureka搭建注冊中心 使用spring initializr創建spring cloud項目 SpringCloud…

FastAPI之聲明請求參數示例數據

在Pydantic模型中添加額外的JSON模式數據 您可以聲明Pydantic模型的示例&#xff0c;這些示例將被添加到生成的JSON模式中。 示例代碼 from fastapi import FastAPI from pydantic import BaseModelapp FastAPI()class Item(BaseModel):name: strdescription: str | None …

(C語言實現)高精度除法 (洛谷 P2005 A/B Problem II)

前言 本期我們分享用C語言實現高精度除法&#xff0c;可通過該題測試點我點我&#xff0c;洛谷 p2005。 那么話不多說我們開始吧。 講解 大家還記不記得小學的時候我們是怎么做除法的&#xff1f;我們以1115為例。 我們的高精度除法也將采用這個思路進行&#xff0c;分別用兩…

在 TS 中解析 ipa 文件

在 TS 中解析 ipa 文件 ipa即Xcode打包出來的APP的安裝包&#xff0c;通過解析ipa中的文件&#xff0c;我們可以獲得APP的DisplayName、Version、BundleIdentifier等信息&#xff0c; 同時也可以獲取到APP證書的相關信息&#xff0c;包括APP的安裝環境、證書的有效期、APP開通…

Python-算術運算符詳解

運算符 算術運算符 關系運算符 邏輯運算符 賦值運算符 算術運算符&#xff1a;加減乘除 %求余 **平方 // 先算乘方&#xff0c;再算乘除&#xff0c;最后是加減。括號可以改變優先級 0不能作為除數&#xff08;不論是整型0還是浮點0&#xff09; 除法截斷&#xff1a;舍棄小…

UDP群聊

客戶端 import java.awt.BorderLayout; import java.awt.Dimension; import java.awt.EventQueue; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader…

LeetCode738. Monotone Increasing Digits

文章目錄 一、題目二、題解 一、題目 An integer has monotone increasing digits if and only if each pair of adjacent digits x and y satisfy x < y. Given an integer n, return the largest number that is less than or equal to n with monotone increasing digi…

使用VBA快速統計詞組(單詞組合)詞頻

實例需求&#xff1a;產品清單如A列所示&#xff0c;現在如下統計詞組詞頻。想必各位小伙伴都指定如何使用字典對象實現去重&#xff0c;進而實現單個單詞的詞頻統計。 但是統計詞組詞頻就沒有那么簡單了&#xff0c;為了便于演示&#xff0c;此處的詞組只限于兩個單詞的組合。…

自動駕駛右向輔助功能規范

目 錄 Contents 目錄 1. 介紹 Introduction. 8 1.1 此文檔的范圍和目的 Scope and Purpose of This Document 8 1.2 參考文檔References. 9 1.3 文檔的維護 Maintenance of the Document 10 1.4 縮略詞Abbreviations. 10 1.5 文檔概述Document Overview.. 11 1.6 功能…

GoLong的學習之路,進階,Viper(yaml等配置文件的管理)

本來有今天是繼續接著上一章寫微服務的。但是這幾天有朋友說&#xff0c;再寫Web框架的時候&#xff0c;遇到一個問題&#xff0c;就是很多的中間件&#xff08;redis&#xff0c;微信&#xff0c;mysql&#xff0c;mq&#xff09;的配置信息寫的太雜了&#xff0c;很不好管理。…

【解決辦法】Pycharm中新添加或者導入項目文件名紅色!

提示&#xff1a;文章寫完后&#xff0c;目錄可以自動生成&#xff0c;如何生成可參考右邊的幫助文檔 文章目錄 一、問題描述二、問題原因三、解決辦法 一、問題描述 Pycharm的代碼中添加新的文件夾&#xff0c;發現文件夾下的文件名是紅色的&#xff0c;如下圖&#xff1a; …

jvm-sandbox-repeater 精簡版部署之standalone模式

jvm-sandbox-repeater 僅僅提供了錄制回放的能力&#xff0c;如果需要完成業務回歸、實時監控、壓測等平臺&#xff0c;后面須要有一個數據中心負責采集數據的加工、存儲、搜索&#xff0c;repeater-console提供了簡單的demo示例&#xff1b;一個模塊管理平臺負責管理JVM-Sandb…

設計模式——單例模式(Singleton Pattern)

概述 單例模式確保一個類只有一個實例&#xff0c;而且自行實例化并向整個系統提供整個實例&#xff0c;這個類稱為單例類&#xff0c;它提供全局訪問的方法。單例模式是一種對象創建型模式。單例模式有三個要點&#xff1a;一是某個類只能有一個實例&#xff1b;二是它必須自行…

矩陣基本操作算法

題目描述&#xff1a; 題目描述 根據主函數和頭文件提示&#xff0c;編寫子函數void matrixInput(int (*mat)[COL]); void matrixPrint(int *mat[ROW]); void matrixAddT(int *mat); ? 分別實現矩陣的輸入&#xff0c;輸出&#xff0c;與自身的轉置相加&#xff1a;void matr…

微信小程序開發中的圖片缺少后自動居中問題的解決,自動居中樣式,自適應圖片多少的寫法

下面是寫的wxml的view樣式類似于web開發中的HTML文件 home-grid是我創建的一個父樣式&#xff0c;采用子絕父相的定位方式 我在home-grid的父view&#xff08;類似于web中div&#xff09;中包含了三個小的子樣式分別是下述代碼中的class“yellowstar”&#xff0c;class“maint…

Java---線程講解(二)

文章目錄 1. Runnable接口2. 賣票案例3. 同步代碼塊解決數據安全問題4. 同步方法解決數據安全問題5. 線程安全的類6. Lock鎖 1. Runnable接口 1. 創建線程的另一種方法是聲明一個實現Runnable接口的類&#xff0c;之后重寫run()方法&#xff0c;然后可以分配類的實例&#xff0…

基于remix+metamask+ganache的智能合約部署調用

在我們部署合約時為了讓它更接近真實區塊鏈去中心化體驗&#xff0c;我們需要調用小狐貍&#xff08;Metamask&#xff09;來進行真實交易&#xff0c;而metamask里沒有內置虛擬測試幣&#xff0c;我們需要進行調用Ganache來添加帶有虛擬測試幣的賬號。以上就是三者的關系&…