【Java】基本程序设计结构(二)

前言:上一篇我们详细介绍了Java基本程序设计结构中前半部分,一个简单的Java应用,注释,数据类型,变量与常量,运算符,字符串。包括本篇将延续上篇内容介绍后续内容,包括输入输出,控制流,大数值。
![Alt](https://img-home.csdnimg.cn/images/20220524100510.png#pic_center

文章目录

    • 一.输入输出
      • 1.1读取输入
      • 1.2格式化输出
    • 二.控制流
      • 2.1块作用域
      • 2.2条件语句
      • 2.3循环语句
      • 2.4 switch语句
    • 三.大数值

一.输入输出

为了增加后面示例程序的趣味性,需要程序能够接收输人,并以适当的格式输出。当然,现代的程序都使用GUI(图形用户界面)收集用户的输人,然而,编写这种界面的程序需要使用较多的工具与技术,目前还不具备这些条件。主要原因是需要熟悉Java程序设计语言,因此只要有简单的用于输入输出的控制台就可以了。

1.1读取输入

读取输入前面已经看到,打印输出到“标准输出流”(即控制台窗口)是一件非常容易的事情,只要调用System.out.println即可。然而,读取“标准输入流”System.in就没有那么简单了。要想通过控制台进行输人,首先需要构造一个Scanner对象,并与“标准输入流”System.in关联。

Scanner scanner = new Scanner(System.in);

现在,就可以使用Scanner类的各种方法实现输入操作了。

System. out. print("What is your name? ");
String name = in. nextLine();

在这里,使用nextLine方法是因为在输人行中有可能包含空格。要想读取一个单词(以空白符作为分隔符),就调用

String firstName = in. next();

要想读取一个整数,就调用nextInt方法。

System. out. print("How old are you? ");
int age = in. nextInt();

与此类似,要想读取下一个浮点数,就调用nextDouble方法。
接下来看一个示例:

import java.util.*;

public class InputTest{
	public static void main(String[] args){
		Scanner in=new Scanner(System.in);

		//获取第一个输入
		System.out.println("你的名字是?");
		String name=in.nextLine();
		//获取第二个输入
		System.out.println("你的年龄是?");
		int age=in.nextInt();
		//显示结果到控制台上
		System.out.println("Hello"+name+"Next Year you will be"+(age+1));
	}
}

当使用的类不是定义在基本java.lang包中时,一定要使用import指示字将相应的包加载进来。否则在dos命令行中就会出现以下错误:
在这里插入图片描述
引入了包之后,我们就能得到:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

1.2格式化输出

可以使用 System . out . print (x)将数值x输出到控制台上。这条命令将以x对应的数据类型所允许的最大非0数字位数打印输出x。
例如:

double x = 10000.0/3.0;
System.out.prinln(x);//3333.3333333333335

如果希望显示美元、美分等符号,则有可能会出现问题。
在早期的Java版本中,格式化数值曾引起过一些争议。庆幸的是,JavaSE5.0沿用了C语言库函数中的printf方法。例如,调用System.out.printf("%8.2f", x);可以用8个字符的宽度和小数点后两个字符的精度打印x。也就是说,打印输出一个空格和7个字符,如下所示:3333.33
在printf中,可以使用多个参数,例如:System.out. printf("Hello, %s. Next year, you'll be %d", name, age);这和C语言的格式化输出是相类似的。每一个以%字符开始的格式说明符都用相应的参数替换。格式说明符尾部的转换符将指示被格式化的数值类型:f表示浮点数,s表示字符串,d表示十进制整数。具体如下表:
在这里插入图片描述
另外,还可以给出控制格式化输出的各种符号标志,例如:

System.out.print("%,.2f",10000.0/3.0);
//333,3.33

可以使用多个标志,例如:"%,(.2f"表示使用分组的分隔符并将负数括在括号内。更多标志如下图:
在这里插入图片描述
在这里插入图片描述
格式说明符具体使用也是有顺序的,如下:
在这里插入图片描述

二.控制流

与任何程序设计语言一样,Java使用条件语句和循环结构确定控制流程。我们先讨论条件语句,然后讨论循环语句,最后介绍看似有些笨重的switch语句,当需要对某个表达式的多个值进行检测时,可以使用switch语句。

2.1块作用域

在深入学习控制结构之前,需要了解块(block)的概念。块(即复合语句)是指由一对花括号括起来的若干条简单的Java语句。块确定了变量的作用域。一个块可以嵌套在另一个块中。但是我们不能在嵌套的块中两次声明一个同名的变量(即使C++是允许的,但是Java认为这是十分不安全的)。例如下面示例就是一个错误示范:
在这里插入图片描述

2.2条件语句

在Java中,条件语句的格式为if (condition) {statement}这里的条件必须用括号括起来。与绝大多数程序设计语言一样,Java常常希望在某个条件为真时执行多条语句。在这种情况下,应该使用块语句(block statement)。

if(yourSales>target)
{
//statement1
//statement2
//...
}

与C一样,比较常见的条件语句除了上面的示例还有下面两种:
1>if——else型:(仅仅理解结构即可,内容不作理会)
在这里插入图片描述
注意:这里的else遵循就近原则——即else只会与离它最近的if配对。所以在使用的时候一定要分清else和哪一个if是相对应的。
2>if——else if——else型:
在这里插入图片描述

2.3循环语句

与C语言一样,Java中的循环语句同样有三种。总的来说分为不确定循环确定循环

不确定循环:
1.while循环

2.do-while循环

while与do-while语句最大的区别就是do_while循环的语句会至少执行一次,而while语句可能一次都不执行。
因为对于while语句来说首先要要判断条件是否为true,只有当条件为true的时候才会继续向下进行。
在这里插入图片描述
在这里插入图片描述

确定循环:
for循环

for循环语句是支持迭代的一种通用结构,利用每次迭代后更新计数器来控制迭代次数。

for(1;2;3){statement}

for语句的第1部分通常用于对计数器初始化;第2部分给出每次新一轮循环执行前要检测的循环条件;第3部分指示如何更新计数器。
示例如下:

for(int i=1;i<=10;i++){
	System.out.print(i);
	//打印1到10
}

此外,Java中还提供一种很强的循环结构,可以用来处理依次数组(或其他元素集合)中的每一个元素,而不必考虑指定下标值。
它的格式如下:

for(寄存变量:目标集合)

我们可以使用for each循环处理一维数组或二维数组,示例如下:

int[] num = new int[10];
for (int i = 0; i < data.length; i++)
    data[i] = i ;
for (int NUM : num)
    System.out.printf("%d\t", NUM + 10);
    //10 11	12...

int[][] form = new int[10][5];
for (int i = 0; i < form.length; i++) {
    for (int j = 0; j < form[0].length; j++) {
        form[i][j] = i * j;
    }
}
for (int[] form1 : form) {
    for (int form2 : form1)
        System.out.printf("%d\t", form2);
    System.out.println();  
 /* 0	0	0	0	0	
	0	1	2	3	4	
	0	2	4	6	8	
	0	3	6	9	12	
	0	4	8	12	16	
	0	5	10	15	20	
	0	6	12	18	24	
	0	7	14	21	28	
	0	8	16	24	32	
	0	9	18	27	36	
*/ 
}

2.4 switch语句

switch语言用于处理多个选项。此时使用if/else就会略显笨拙。Java有一个和C/C++完全相同的switch语法:

switch(表达式){
 case 常量值1:{
 语句1;
 [break;]
 }
 case 常量值2:{
 语句2;
 [break;]
 }
 /*执行流程:
1. 先计算表达式的值
2. 和case依次比较,一旦有响应的匹配就执行该项下的语句,直到遇到break时结束
3. 当表达式的值没有与所列项匹配时,执行default
代码示例: 根据 day 的值输出星期
 
【注意事项】
多个case后的常量值不可以重复
switch的括号内只能是以下类型的表达式:
基本类型:byte、char、short、int,注意不能是long类型
引用类型:String常量串、枚举类型
 
 ...
 default:{
 内容都不满足时执行语句;
 [break;]
 } */
}

由于Java是一种强类型的语言,如果swtich后面括号的表达式不符合上面所述类型,就会出现报错:

double num = 1.0;
switch(num) {
    case 1.0:
        System.out.println("hehe");
        break;
    case 2.0:
        System.out.println("haha");
        break;
}
 
// 编译出错
//Test.java:4: 错误: 不兼容的类型: 从double转换到int可能会有损失

此外,switch语句还要注意以下几点:

  • break不能丢失,不然会失去“多分支选择”的功能;
int day = 1;
switch(day) {
    case 1:
        System.out.println("星期一");
        // break;
    case 2:
        System.out.println("星期二");
        break;
}
 
// 运行结果
星期一
星期二
  • switch语句支持嵌套,但是很丑,一般不建议;
int x = 1;
int y = 1;
switch(x) {
    case 1:
        switch(y) {
            case 1:
                System.out.println("hehe");
                break;
       }
  • switch后面括号不能表达复杂的条件。
// 例如: 如果 num 的值在 10 到 20 之间, 就打印 hehe
// 这样的代码使用 if 很容易表达, 但是使用 switch 就无法表示. 
if (num > 10 && num < 20) {
 System.out.println("hehe");
}

三.大数值

如果基本的整数和浮点数精度不能够满足需求,那么可以使用java.math包中的两个很有用的类:BigIntegerBigDecimal。这两个类可以处理包含任意长度数字序列的数值。BigInteger类实现了任意精度的整数运算,BigDecimal实现了任意精度的浮点数运算。使用静态的valueOf方法可以将普通的数值转换为大数值:BigInteger a = BigInteger. valueOf(100);
遗憾的是,不能使用人们熟悉的算术运算符(如:+和*)处理大数值。而需要使用大数值类中的*addmultiply方法。

在这里插入图片描述
下面的程序示例是一个彩票抽奖的改进代码,使其可以采用大数值进行运算。假设你被邀请参加抽奖活动,并从490个可能的数值中抽取60个,这个程序将会得到中彩概率1/716395843461995557415116222540092933411717612789263493493351013459481104668848。祝你好运!改进前,用于计算的语句是lotteryOdds = lotteryOdds * (n - i + 1) / i;
如果使用大数值,则相应的语句为:
lotteryOdds = lotteryOdds.multiply(BigInteger.valueOf(n - i + 1)).divide(BigInteger.valueOf(i));
(感兴趣的同学了解一下)

import java.math.BigInteger;
import java.util.Scanner;

/**
 * @author 维C果糖
 * @create 2017-02-15
 */

public class ExOfBigValue {
    /**
     * 模拟彩票中奖的概率
     */
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        System.out.println("请输入您的幸运数字:");
        int k = sc.nextInt();
        System.out.println("请输入您能想到的最大整数:");
        int n = sc.nextInt();

        /**
         * 计算的二项式系数为:n*(n-1)*(n-2)*...*(n-k+1)/(1*2*3*...*k)
         */
        BigInteger bi = BigInteger.valueOf(1);

        for (int i = 1; i <= k ; i++) {
            bi = bi.multiply(BigInteger.valueOf(n - i + 1)).divide(BigInteger.valueOf(i));
        }

        System.out.println("您中奖的概率是 1/" + bi + ",祝您好运!");
    }
}

感谢观看至此,以上就是对Java基本程序设计结构(一)的一些补充,希望屏幕前的你能有所收获,下一篇将对Java中的数组这一非常重要概念作以详细介绍,希望大家持续关注!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/594268.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

UE5 UMG

锚点 参考链接&#xff1a;虚幻5UI系统&#xff08;UMG&#xff09;基础&#xff08;已完结&#xff09;_哔哩哔哩_bilibili

政安晨:【Keras机器学习示例演绎】(三十七)—— 在计算机视觉中学习调整大小

政安晨的个人主页&#xff1a;政安晨 欢迎 &#x1f44d;点赞✍评论⭐收藏 收录专栏: TensorFlow与Keras机器学习实战 希望政安晨的博客能够对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出指正&#xff01; 本文目标&#xff1a;在计算机视觉中学习调整大小…

数据结构(十一)----图的应用

目录 一.最小生成树 1.Prim算法&#xff08;普里姆&#xff09; 2.Kruskal算法(克鲁斯卡尔): 二.最短路径&#xff08;BFS算法&#xff09; 1.单源最短路径 &#xff08;1&#xff09;BFS算法&#xff08;无权图&#xff09; &#xff08;2&#xff09;Dijkstra算法&…

QT+网络调试助手+TCP客户端

一、网络调试助手UI界面 编程主要思路&#xff1a; 首先将水平的控件 水平布局 &#xff0c;然后相对垂直的控件 垂直布局 &#xff0c;哪怕是底下的groupBox也需要和里面的内容 水平布局&#xff0c;然后最后框选全部 栅格布局。如果需要界面自适应窗口大小&#xff0c…

JavaScript js写九九乘法表(两种方法)

方法一&#xff1a; 观察规律&#xff1a; 第一个数每行都是自增1。 我们发下第二个数都是从1开始&#xff0c;依次递增1&#xff0c;永远不大于前面的数。 前面数字每自增一次&#xff0c;后面数字自增一轮。 我们可以用双重for循环&#xff0c;外层初始值设为i&#xff0…

【C++】对文章分词,并对词频用不同排序方法排序,比较各排序算法效率

文章分词 1&#xff0e;问题描述2&#xff0e;需求分析3&#xff0e;概要设计3.1 主程序流程3.2 函数调用关系 4&#xff0e;主函数实现4.1 main.h4.2 main.cpp 5. 函数实现5.1 processDic函数5.2 forwardMax函数5.3 countWordFreq函数5.4 quickResult函数5.5 其它排序算法效率…

【链表】:链表的带环问题

&#x1f381;个人主页&#xff1a;我们的五年 &#x1f50d;系列专栏&#xff1a;数据结构 &#x1f337;追光的人&#xff0c;终会万丈光芒 前言&#xff1a; 链表的带环问题在链表中是一类比较难的问题&#xff0c;它对我们的思维有一个比较高的要求&#xff0c;但是这一类…

十二、泛型

这里写自定义目录标题 一、什么是泛型二、为什么需要泛型&#xff1f;三、自定义泛型结构1、泛型类2、泛型方法 四、泛型在继承上的体现五、通配符的使用1、注意点2、有限制的通配符 一、什么是泛型 泛型就是定义类、接口时通过一个标识表示类中某个属性的类型 、方法的返回值…

C#实现简单音乐文件解析播放——Windows程序设计作业2

1. 作业内容 编写一个C#程序&#xff0c;要求实现常见音乐文件的播放功能&#xff0c;具体要求如下&#xff1a;     1). 播放MP3文件&#xff1a; 程序应能够读取MP3文件&#xff0c;并播放其中的音频。     2). 播放OGG文件&#xff1a; 应能够播放ogg文件。     …

学习3:scrapy请求对象、模拟登录、POST请求、管道的使用、crawlspider爬虫类

请求对象 请求对象参数 scrapy.Request(url[],callback,method"GET",headers,body,cookies,meta,dont_filterFalse)callback 表示当前的url响应交给那个函数去处理method 指定请求方式headers 接受一个字典&#xff0c;其中不包括cookiesbody 接收json字符串&#…

OpenCV的周期性噪声去除滤波器(70)

返回:OpenCV系列文章目录&#xff08;持续更新中......&#xff09; 上一篇:OpenCV如何通过梯度结构张量进行各向异性图像分割(69) 下一篇 :OpenCV如何为我们的应用程序添加跟踪栏(71) 目录 目标 理论 如何消除傅里叶域中的周期性噪声&#xff1f; 源代码 解释 结果 目…

IDEA--debug

1. 单点调试的三个级别 Step into&#xff1a;在单步执行时&#xff0c;遇到子函数就进入并且继续单步执行。Step over&#xff1a;在单步执行时&#xff0c;在函数内遇到子函数时不会进入子函数内单步执行&#xff0c;而是将子函数整个执行完再停止&#xff0c;也就是把子函数…

用树莓派2B当web服务器

树莓派2&#xff0c;卡片大小&#xff0c;arm 32位cpu&#xff0c;512G内存。我找了一下购买记录&#xff0c;2013年12月15日买的。带网线接头。属于树莓派2B。以前下载的操作系统还在。是2014年的操作系统&#xff0c;文件名是&#xff1a;2014-09-09-wheezy-raspbian_shumeip…

C语言之整形提升和算术转换

目录 前言 一、整形提升 二、算术转换 总结 前言 本文主要介绍C语言中的整形提升和算术转换的概念和意义&#xff0c;以及例题帮助理解&#xff0c;了解之后&#xff0c;我们就能知道在C语言中&#xff0c;字符型变量如何计算以及如果变量的类型、字节大小不一致的情况下&am…

前端工程化06-JavaScript模块化CommonJS规范ES Module

7、JavaScript模块化 在js开发中&#xff0c;他并没有拆分的概念&#xff0c;并不像java一样他可以拆分很多的包&#xff0c;很多的类&#xff0c;像搭积木一样完成一个大型项目的开发&#xff0c;所以js在前期的时候并不适合大型后端的项目开发&#xff0c;但是这些问题在后来…

Android 10.0 Launcher3 app页面调整workspace边距app行距变小功能实现

1.前言 在10.0的系统rom定制化开发中,在launcher3的一些开发定制功能中,在对于大分辨率比如1600*2560的设备进行开发的时候, 会在竖屏的时候,在默认7*4的布局的时候,显得行距有点宽,这样就需要调整整个CellLayout的上下左右边距,然后就 会显得行距会小一点,接下来具体…

ASP.NET网上书店

摘要 本设计尝试用ASP.NET在网络上架构一个电子书城&#xff0c;以使每一位顾客不用出门在家里就能够通过上网来轻松购书。本文从理论和实践两个角度出发&#xff0c;对一个具有数据挖掘功能电子书城进行设计与实现分析。论文首先较为详尽地介绍了面向对象分析与设计的有关概念…

基于Springboot的房屋租赁管理系统(有报告)。Javaee项目,springboot项目。

演示视频&#xff1a; 基于Springboot的房屋租赁管理系统&#xff08;有报告&#xff09;。Javaee项目&#xff0c;springboot项目。 项目介绍&#xff1a; 采用M&#xff08;model&#xff09;V&#xff08;view&#xff09;C&#xff08;controller&#xff09;三层体系结构…

图中有几个三角形

让我们先把三角形进行分类&#xff1a;1块组成的三角形、2块组成的三角形、依此类推。 1块组成的三角形有4个&#xff1a; 2块组成的三角形有&#xff1a;12,13,14,23,24,34.其中&#xff0c;14&#xff0c;23构不成三角形. 3块组成的三角形有&#xff1a;123,124,134,234。但…

贪心算法(活动选择、分数背包问题)

一、贪心算法 贪心算法是指&#xff1a;在对问题求解时&#xff0c;总是做出在当前看来是最好的选择&#xff0c;而不从整体最优考虑&#xff0c;做出的仅是在某种意义上的局部最优解。 …