【探索Java编程:从入门到入狱】Day5

2024-05-09 10:36

本文主要是介绍【探索Java编程:从入门到入狱】Day5,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

🍬 博主介绍👨‍🎓 博主介绍:大家好,我是 hacker-routing ,很高兴认识大家~
✨主攻领域:【渗透领域】【应急响应】 【Java、PHP】 【VulnHub靶场复现】【面试分析】
🎉点赞➕评论➕收藏 == 养成习惯(一键三连)😋
🎉欢迎关注💗一起学习👍一起讨论⭐️一起进步📝文末有彩蛋
🙏作者水平有限,欢迎各位大佬指点,相互学习进步!

目录

0x1 前言

0x2 基本数据类型

1、基本数据类型

1.1.1、自动类型转换

1.1.2、强制类型转换

0x3 练习题-2176 · 求数组最大值

描述

解法一:for 循环、if 语句

解法二:for 循环、Math 类

示例:

0x4 判断和循环-03-if的第二种格式和练习

if语句的第二种格式

练习-吃饭

练习-商品付款

练习-影院选座


0x1 前言

练习Java代码平台这里还是给师傅们推荐炼码https://www.lintcode.com/这个平台不错,有知识点学习以及代码学习。题目位置如下:LintCode 炼码 - ChatGPT!更高效的学习体验!

0x2 基本数据类型

变量就是申请内存来存储值。也就是说,当创建变量的时候,需要在内存中申请空间。

内存管理系统根据变量的类型为变量分配存储空间,分配的空间只能用来储存该类型数据。

因此,通过定义不同类型的变量,可以在内存中储存整数、小数或者字符。

Java 的两大数据类型:

  • 基本数据类型
  • 引用数据类型

1、基本数据类型

Java 语言提供了八种基本类型。六种数字类型(四个整数型,两个浮点型),一种字符类型,还有一种布尔型。

byte:

  • byte 数据类型是 8 位、有符号的,以二进制补码表示的整数;
  • 最小值是 -128(-2^7)
  • 最大值是 127(2^7-1)
  • byte 类型用在大型数组中节约空间,主要代替整数,因为 byte 变量占用的空间只有 int 类型的四分之一;
  • 默认值是 0
// 例子:
byte a = 100;
byte b = -50;

short:

  • short 数据类型是 16 位、有符号的以二进制补码表示的整数
  • 最小值是 -32768(-2^15)
  • 最大值是 32767(2^15 - 1)
  • short 数据类型也可以像 byte 那样节省空间。一个 short 变量是 int 型变量所占空间的二分之一;
  • 默认值是 0
// 例子:
short s = 100;
short r = -20000;

int:

  • int 数据类型是 32 位、有符号的以二进制补码表示的整数;
  • 最小值是 -2,147,483,648(-2^31)
  • 最大值是 2,147,483,647(2^31 - 1)
  • 一般地整型变量默认为 int 类型;
  • 默认值是 0
// 例子:
int a = 100000;
int b = -200000;

long:

  • long 数据类型是 64 位、有符号的以二进制补码表示的整数;
  • 最小值是 -9,223,372,036,854,775,808(-2^63)
  • 最大值是 9,223,372,036,854,775,807(2^63 -1)
  • 这种类型主要使用在需要比较大整数的系统上;
  • 默认值是 0L
  • L 理论上不分大小写,但是若写成 l 容易与数字 1 混淆,不容易分辩。所以最好大写。
// 例子: 
long a = 100000L;
Long b = -200000L;

float:

  • float 数据类型是单精度、32 位、符合 IEEE 754 标准的浮点数;
  • float 在储存大型浮点数组的时候可节省内存空间;
  • 默认值是 0.0f
  • 浮点数不能用来表示精确的值,如货币;
//例子:
float f1 = 234.5f;

double:

  • double 数据类型是双精度、64 位、符合 IEEE 754 标准的浮点数;
  • 浮点数的默认类型为 double 类型;
  • double 类型同样不能表示精确的值,如货币;
  • 默认值是 0.0d
// 例子:
// 7 是一个 int 字面量,而 7D,7. 和 8.0 是 double 字面量。
double d1 = 7D ;
double d2 = 7.; 
double d3 = 8.0; 
double d4 = 8.D; 
double d5 = 12.9867; 

boolean:

  • boolean 数据类型表示一位的信息;
  • 只有两个取值:true 和 false;
  • 这种类型只作为一种标志来记录 true/false 情况;
  • 默认值是 false
// 例子:
boolean a1 = true;
boolean a2 = false;

char:

  • char 类型是一个单一的 16 位 Unicode 字符;
  • 最小值是 \u0000(十进制等效值为 0);
  • 最大值是 \uffff(即为 65535);
  • char 数据类型可以储存任何字符;
// 例子:
char letter = 'A';

1.1、数据转换 整型、实型(常量)、字符型数据可以混合运算。运算中,不同类型的数据先转化为同一类型,然后进行运算。

// 转换从低级到高级。
// 低  ------------------------------------>  高
byte/short/char —> int —> long —> float —> double 

数据类型转换必须满足如下规则:

  • 不能对 boolean 类型进行类型转换。
  • 不能把对象类型转换成不相关类的对象。
  • 在把容量大的类型转换为容量小的类型时必须使用强制类型转换。
  • 转换过程中可能导致溢出或损失精度,例如:
int i =128;   
// 因为 byte 类型是 8 位,最大值为127,所以当 int 强制转换为 byte 类型时,值 128 时候就会导致溢出。
byte b = (byte) i;
System.out.println(b);  // 127

  • 浮点数到整数的转换是通过舍弃小数得到,而不是四舍五入,例如:
int a = (int) 23.7;       
int b = (int) -45.89f;
System.out.println(a);  // 23
System.out.println(b);  // -45

1.1.1、自动类型转换

必须满足转换前的数据类型的位数要低于转换后的数据类型,例如: short 数据类型的位数为 16 位,就可以自动转换位数为 32 的 int 类型,同样 float 数据类型的位数为 32,可以自动转换为 64 位的 double 类型。

public class Main{public static void main(String[] args){// 定义一个 char 类型char c1='a';  // char 自动类型转换为 intint i1 = c1;  // char 自动类型转换为 int 后的值等于 97System.out.println("char 自动类型转换为 int 后的值等于" + i1);  // 定义一个 char 类型char c2 = 'A';  // char 类型和 int 类型计算int i2 = c2 + 1;  // char 类型和 int 计算后的值等于 66System.out.println("char 类型和 int 计算后的值等于" + i2);     }
}
1.1.2、强制类型转换
  • 条件是转换的数据类型必须是兼容的。
  • 格式:(type)value type 是要强制类型转换后的数据类型 实例:
public class Main{public static void main(String[] args){int i1 = 123;// 强制类型转换为 bytebyte b = (byte) i1;  // int 强制类型转换为 byte 后的值等于 123System.out.println("int 强制类型转换为 byte 后的值等于" + b);  }
}

1.1.3、隐含强制类型转换 整数的默认类型是 int。 小数默认是 double 类型浮点型,在定义 float 类型时必须在数字后面跟上 F 或者 f。

0x3 练习题-2176 · 求数组最大值

描述

请编写 Java 语句,求出数组最大值,实现该题的方法有很多种,我们推荐使用 for 循环遍历数组和比较运算符来实现。本题提供了 Solution 类,Solution 类中有一个 getMax 方法,该方法传递了一个 int[] 类型的参数 array,返回数组中的最大值,且是 int 类型。

public class Solution {/**** @param array: array represents an array* @return : represents the maximum value of the array to be returned*/public int getMax(int[] array) {// write your code here}
}

解法一:for 循环、if 语句

本题要求数组中的最大值,我们可以定义一个变量用来存放最大值,然后我们需要依次把数组中的元素取出,将数组第一个元素暂时当作最大值,再依次跟后面的元素作比较,如果后面的元素较大,就把较大的元素赋值给最大值变量,一直到数组中的元素全部比较完。最后返回最大值变量。

源代码:

public class Solution {/**** @param array: array代表一个数组* @return : 表示要返回的数组的最大值*/public int getMax(int[] array) {//这里默认第一个元素是最大值int max = array[0];//然后拿这个第一个元素跟后面的进行比较//for循环,用来取出数组中的元素for (int i = 0; i < array.length; i++) {//if用来判断数组中的最大值if (max <= array[i]){max = array[i];}}return max;}
}

解法二:for 循环、Math 类

解题思路

本题要求数组中的最大值,我们可以定义一个变量用来存放最大值,然后我们需要依次把数组中的元素取出,将数组第一个元素暂时当作最大值,然后使用数学类中的 max 方法得出较大的元素,再赋值给这个最大值变量。最后返回这个最大值变量。

package 炼码;public class demon_2176 {public int getMax(int[] array) {//这里默认第一个元素是最大值int max = array[0];//使用for循环,max方法for (int i = 0; i < array.length; i++) {max = Math.max(max,array[i]);}return max;}
}

for 循环的表达式

for (初始化; 布尔表达式; 更新) {// 代码语句
}

示例:

使用 for 循环打印 10 次 Hello Java!

package 炼码;public class demon_2176 {public static void main(String[] args) {// for循环,打印10次hello javafor (int i = 0; i < 10; i++) {System.out.println("hello java");}}
}

0x4 判断和循环-03-if的第二种格式和练习

if语句的第二种格式

练习-吃饭

利用if else语句进行判断:

package heima;import java.util.Scanner;public class test {public static void main(String[] args) {/*需求:* 键盘录入一个整数,表示身上的钱。如果大于等于100块,就是网红餐厅。否则,就吃经济实惠的沙县小吃。* *///1、键盘录入数值Scanner sc = new Scanner(System.in);System.out.println("请录入身上的钱:");int money = sc.nextInt();if (money >= 100) {System.out.println("吃网红餐厅");}else {System.out.println("吃沙县小吃");}}
}

练习-商品付款

package heima;import java.util.Scanner;public class test {public static void main(String[] args) {//1、键盘录入一个整数表示用户实际支付的钱Scanner sc = new Scanner(System.in);System.out.println("录入一个整数表示实际支付的钱:");int money = sc.nextInt();//2、 if判断if (money >= 600){System.out.println("支付成功");}else {System.out.println("支付失败");}}
}

练习-影院选座

package heima;import java.util.Scanner;public class test {public static void main(String[] args) {//1、键盘录入一个整数表示电影票的票号Scanner sc = new Scanner(System.in);System.out.println("请输入一个票号:");int ticket = sc.nextInt();//限定票号的范围在0~100之间if (ticket >= 0 && ticket <= 100){//2、判断票号是奇数还是偶数if (ticket % 2 == 1){System.out.println("做左边");}else {System.out.println("做右边");}}}
}

这篇关于【探索Java编程:从入门到入狱】Day5的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/973170

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟&nbsp;开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚&nbsp;第一站:海量资源,应有尽有 走进“智听