0

0

更基本的语法 - 循环和异常

WBOY

WBOY

发布时间:2024-08-21 08:20:05

|

964人浏览过

|

来源于dev.to

转载

本周是毫无成效的一周之一。我在训练营内容上没有取得太大进展,但我设法涵盖了本模块的最后一个理论单元:

更基本的语法 - 循环和异常

java 和大多数源自 c 的高级语言一样,具有三种基本类型的重复循环(著名的循环):for、while 和 do-while。

for 当我们预先知道将用作可迭代对象(如数组)的元素的大小时使用。该元素可能会动态变化(例如,从 api 接收数据),因此可能是作为开发人员,您并不确切知道可迭代将有多少个元素,但是代码会知道。它的基本结构是:

int[] numbers = {1, 2, 3, 4, 5};
for (int counter = 0; counter < numbers.length; counter++) {
    system.out.println(numbers[counter]);
}

第一部分,int计数器=0就是我们所说的count变量
肯定有更漂亮的名字,但这一个可以解释它的作用。她基本上……数了数。

更基本的语法 - 循环和异常

我们将其初始化为 0,在第二部分中,我们将其与 array 数字的大小进行比较。这就是我们所说的condition。只要这个条件为真(即返回真),loop就会继续。
它不一定需要与某些迭代进行比较,但通常会以这种方式使用,最后,我们有counter change,它可以是增量或减量。这种改变也不是必须一一进行,但这是最常见的事情。

另一方面,while 循环不提供这些有限的迭代次数。它检查条件是否为真,如果是,则采取一些操作。它的结构是这样的:

boolean podejavascriptnoback = false;
while (!podejavascriptnoback) {
    system.out.println("tá proibido javascript no back-end.");
};

循环声明中括号之间的是条件,将测试它是否继续。只要该条件的结果为真,就会执行大括号之间的操作。这些信息很重要,因为我们可以从中得出一些结论:

MediPro企业网站管理系统
MediPro企业网站管理系统

一款基于PHP+MYSQL开发的企业网站管理软件,具有灵活的栏目内容管理功能和丰富的网站模版,可用于创建各种企业网站。v5.1版本支持了PHP5+MYSQL5环境,前台网站插件开放源码,更利于个性化的网站开发。具有以下功能特点和优越性:[>]模版精美实用具有百款适合企业网站的精美模版,并在不断增加中[>]多语言支持独立语言包,支持GBK,UTF8编码方式,可用于创建各种语言的网站[&g

下载
  1. loop的动作只有在条件为正时才会发生。如果在任何给定的迭代中条件的值发生变化(从 true 到 false),循环就会中断,并且不会执行该循环的操作;
  2. 可能有一些loop不执行任何操作,因为自第一次迭代以来条件被评估为 false;
  3. 如果不采取任何行动来改变条件的结果,我们会发现自己面临着无限loop.

do-while 与 while 非常相似,不同之处在于操作发生在before条件被检查。这意味着循环在被中断之前将至少执行一项操作。语法与 while 非常相似:

boolean condition = true;
do {
    system.out.println("i'm inside a loop tee-hee!");
} while (condition);

和while一样,如果没有任何动作来改变条件的结果,我们将处理一个无限loop.# ??#

为了更好地控制循环流程,仍然有关键字“break”和“continue”。 break 中断整个循环,而 continue 仅中断当前迭代。例如:


for (int i = 0; i <= 5; i++) {
    if (i == 4) break;
    system.out.println(i); //0 1 2 3
}

在此示例中,for 将运行直到计数器 i 大于或等于数字 5,并且在每次迭代时,当前计数器将打印在控制台上。但当计数器等于4时,循环就会中断,最后两个数字不会被打印。

现在,假设您需要在控制台中打印 1 到 10 的奇数。我们可以使用下面的结构继续:


for (int i = 0; i <= 10; i++) {
    if (i % 2 == 0) continue;
    system.out.println(i); //1 3 5 7 9
}

即从0到10,

loop将使用module检查计数器是否能被2整除。如果是,则循环将跳到下一次迭代,如果不是,则 i 的值将打印在终端中。

到目前为止还算平静吧?让我们继续进行异常处理。

在开发应用的过程中,难免会出现问题。在 java 中,严重问题和简单问题之间是有区别的,严重问题会影响应用程序所在的系统或环境(错误),并且通常是不可恢复的情况,而较简单的问题是应用程序设法以某种方式解决的问题(例外)。#? ?#

如果出现错误,可能是物理问题(例如 outofmemoryerror)、可用资源耗尽(例如 stackoverflowerror),甚至是 jvm 本身的错误(内部错误)。需要注意的是,在这种情况下,没有办法治疗。这种情况会破坏应用程序并通常使其进入不可恢复的状态。

但是有一类问题

可以

恢复:异常。异常是可以捕获并正确处理的问题,这样我们的程序就不会在客户面前崩溃。异常的原因多种多样,包括基础设施问题(例如读/写数据、连接到 sql 数据库等)或逻辑问题(例如无效参数错误)。 为了执行错误处理,通常使用try-catch块。该结构尝试执行一个操作(在 try 块中描述),如果发现异常,它会捕获该问题并处理它(在 catch 块中描述)。它遵循以下语法:

try {
    double result = 10 / 0; //isso vai lançar um arithmeticexception
    system.out.println(result);
} catch (exception e) {
    system.out.println("não é possível dividir por 0, mané.");
}

我们可以声明几个链接在一起的catch块,尝试根据发现的错误来细化处理:

try {  
    int result = 10 / 0; 
    system.out.println(result);  
} catch (arithmeticexception e) {  
    system.out.println("não é possível dividir por 0, mané.");
} catch (nullpointerexception e) {
    system.out.println("alguma coisa que você informou veio nula, bicho.");
} catch (exception e) {  
    system.out.println("deu ruim, irmão. um erro genérico ocorreu: " + e.getmessage());  
}

此外,在整个结构的末尾,我们可以声明一个始终执行的代码块,无论流程采用的路径如何:finally:

try {  
    int result = 10 / 0; 
    system.out.println(result);  
} catch (arithmeticexception e) {  
    system.out.println("não é possível dividir por 0, mané.");
} catch (nullpointerexception e) {
    system.out.println("alguma coisa que você informou veio nula, bicho.");
} catch (exception e) {  
    system.out.println("deu ruim, irmão. um erro genérico ocorreu: " + e.getmessage());  
} finally {
    system.out.println("cabô.");
}

在这个例子中,代码将尝试将 10 除以 0。然后,它将进入第一个 catch 块并打印“

can't split by 0, dude.

”并且,最后,输入finally块并打印“cabô”。不管走哪条路,无论try是否成功,finally都会被执行。 就这些了吗?不! java 中没有什么是简单的。

异常可以分为两种:

verified
异常(受检异常)和非受检异常。在检查异常的情况下,编译器要求对其进行处理,以防止超出代码范围的条件影响应用程序流程。例如,程序正在使用的数据库可能有问题,连接可能会失败。 java 不会简单地显示错误,而是要求您执行如下操作:

public class DatabaseExample {
    public static void main(String[] args){
        try {
            Connection conn = getConnection();
            //executa alguma ação aqui...
        } catch (SQLException e) {
            System.out.println("Não foi possível conectar ao banco de dados. Erro: " + e.getMessage());
        }
    }

    public static Connection getConnection() throws SQLExeption {
        String url = "jdbc:mysql://localhost:3306/mydatabase";
        String user = "user";
        String password = "mySuperSecretPassword"; //por favor não armazenem senhas no código

        //isso pode lançar um erro de SQL
        return DriverManager.getConnection(url, user, password);
    }
}

getconnection() 方法尝试使用提供的凭据连接到数据库,但如果在任何时候出现问题(数据库处于

offline

,凭据错误,机器与网络断开连接等),将抛出异常。 main 方法调用 getconnection(),捕获此异常并通知用户在建立连接时出现错误,而不仅仅是显示堆栈跟踪。 编译器要求实施这种处理,以保护应用程序免受开发人员无法控制的错误的影响,使程序更具弹性和抗故障能力。

未检查异常是不需要

mandatorily

处理的异常。这些是类的方法在开发人员的控制之下的情况,一般来说,代码中存在某种类型的错误(逻辑或 api 的错误使用)。其中一些例子是著名的 illegalargumentexception、arrayindexoutofboundsexception 和 nullpointerexception。 这是否意味着,如果编译器没有抱怨,我就不需要实施处理? 不,对吧?最好有一条友好的错误消息,以便用户知道发生了什么,而不是将其发送到这里:

更基本的语法 - 循环和异常将所有内容放入try-catch中即成功。

最后,

debugging

上有一个使用 intellij 和 eclipse 的模块,它比理论更实用。然而,我无法将指令给出的信息呈现给文本媒介。以后会写一篇关于java调试的文章。 本单元剩下的两个模块很实用(

finally!

)。下一篇文章将会有很多代码。到时候见!

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

727

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

328

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

350

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1263

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

360

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

841

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

581

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

423

2024.04.29

Golang 网络安全与加密实战
Golang 网络安全与加密实战

本专题系统讲解 Golang 在网络安全与加密技术中的应用,包括对称加密与非对称加密(AES、RSA)、哈希与数字签名、JWT身份认证、SSL/TLS 安全通信、常见网络攻击防范(如SQL注入、XSS、CSRF)及其防护措施。通过实战案例,帮助学习者掌握 如何使用 Go 语言保障网络通信的安全性,保护用户数据与隐私。

2

2026.01.29

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 812人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号