💕前言:作者是一名正在学习JAVA的初学者,每天分享自己的学习笔记,希望能和大家一起进步成长💕

目录
💕前言:作者是一名正在学习JAVA的初学者,每天分享自己的学习笔记,希望能和大家一起进步成长💕
+、-、*、/ 加减乘除
% 取余
++、--
1.自动类型提升
当容量小的数据类型的变量与容量大的数据类型的变量做运算时,结果自动提升为容量大的数据类型
char 、byte 、short -> int -> long -> float -> double
2.强制类型转换
需要强制转换符(),并且精度会有损失。
float f = 1.9f;
int a = (int)f; -> 输出1
= 、+=、-=、*=、/=、%=
==(等于)、!=(不等于)、>(大于)、>=(大于等于)、<(小于)、<=(小于等于)
&(与):(并且) 多个表达式在进行计算时,每一个表达式都为true的时候,整体的结果是true(即使第一个为false,他还是会继续判断后面的表达式结果)。
&&(短路与): 与&效果一样,不同在于当第一个表达式为false时,不再判断后面的表达式
|(或):每个表达式计算的时候,只要有一个表达式为true,那结果为true
||(短路或): 与|效果一样,
!(取反): !true 为false
条件表达式的结构一定是true或者false。为true则执行大括号内的语句
语法: if(条件判断表达式){
执行语句
}
语法: if(条件判断表达式){
执行语句
}else{
执行语句
}
语法: if(条件判断表达式){
执行语句
}else if(条件判断表达式){
执行语句
}else{
执行语句
}
说明:
switch(表达式){
case 常量1:
执行语句1;
break;
case 常量2:
执行语句2;
break;
default:
执行语句;
Break;
}
语法: 逻辑表达式1 ?表达式3:表达式4
String str = score>90?"优秀":"不优秀"
逻辑表达式1如果运算结果为true,则整个表达式的结果就是表达式3
逻辑表达式1如果运算结果为false,则整个表达式的结果就是表达式4
表达式3和表达式4的结果类型要一致
while(表达式(true/false)){
循环体
}
do{
循环体
}while(表达式);
语法: for(表达式1;表达式2;表达式3){
循环体
}
表达式1: 计数器的初始化,它只初始化一次
表达式2: 循环条件的判断,多次执行
表达式3: 修改计数器,多次执行
跳出循环
分析解决问题所需要的步骤,然后我们用函数来一步一步调用实现。
例子: 把一个大象放进冰箱
面向过程: 1.打开冰箱 2.把大象放入冰箱 3.关上冰箱
面向对象: 1.大象 属性 方法(行走) 2. 冰箱 属性: 方法: (开门、关门)
1.创建一个冰箱, 冰箱自己开门 创建一个大象的对象 大象走进冰箱 这个冰箱关门。
OOP(object oriented programming),面向对象。 java认为万物都是对象
类: 我们把某些具有相同的属性和行为的事物抽象成一类。
类的属性: 八个基本数据类型,引用数据类型: 类,接口,数组
比如: 狗是一个类,那么阿拉斯加、哈士奇、萨摩耶就是这个类的对象。 犹如模板和样本的关系。通过一个模板可以创建多个样例。(注意点: 类是抽象的概念,对象才是真正的实例)
定义类:(类名称:首字母要大写,驼峰式、见名知意)
class 类名称{
属性
方法
}
创建对象的方法 : 类名 变量名 = new 类名();
通过对象可以访问其方法和属性
默认值
| 数据类型 | 默认值 |
|---|---|
| byte | 0 |
| short | 0 |
| int | 0 |
| long | 0 |
| float | 0.0 |
| double | 0.0 |
| boolean | false |
| char | '' |
| 引用数据类型 | null |
引用的数据类型: 类 数组 接口
类的行为用函数
public <static> 返回值类型 方法名 (数据类型: 参数名称){
方法体
<return 返回值>
}
栈:用于存储基本数据类型的值或者是局部变量。先进后出,存取的容量小,存取的速度快
堆: 用于存储引用的数据类型。存取的容量大,速度慢一些
方法区: 存储引用数据类型,存储一些共享的数据(比如说方法)。
局部基本类型变量:
重点: 对象存储在堆中,引用存储在栈中,堆中的每一个对象的数据都是隔离的。 每一个class加载到数据共享区,jvm会解析这个类的内容,方法是每个对象共享的(属性是独立的,方法是每个对象共享的,但是方法内部的属性是哪个对象调用这个方法,那么这个属性就是哪个对象的)
java是通过gc垃圾回收器来回收。
定义: 局部变量是定义在方法中或者语句块中。
属性特点:
作用范围: 只限于所定义的大括号中(以及自括号内)
存储位置: 存储在栈内存中
默认值:无 ,使用时一定要初始化
生命周期: 所属的大括号范围
例子: 所以当dog1=null时,new Dog()这个对象就没人引用了。就会被gc垃圾回收器回收,就是说有可能方法还没有执行完,就被回收了。不过垃圾回收器运行的机制是有jvm判断的。而不是人为操作的。 dog=null,后,不能再使用了,否则会空指针异常。 大括号结束了,局部变量消失了,对象引用也消失了。
定义: 成员变量是定义在类中,也可以叫类的属性
除了成员变量其他都是局部变量
属性的特点:
作用范围: 根据权限的修饰符定(public private protected default)
存储的位置: 堆内存中或者数据共享区(这个在static中会提到)
默认值: 有
生命周期: 由jvm通过垃圾回收机制来回收
匿名对象由于没有栈中的变量来引用,所以会被回收掉,所以匿名对象是没有意义的。
今天的笔记分享就到此为止,感谢大家的观看~~
我真的很习惯使用Ruby编写以下代码:my_hash={}my_hash['test']=1Java中对应的数据结构是什么? 最佳答案 HashMapmap=newHashMap();map.put("test",1);我假设? 关于java-等价于Java中的RubyHash,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/22737685/
我正在尝试使用boilerpipe来自JRuby。我看过guide从JRuby调用Java,并成功地将它与另一个Java包一起使用,但无法弄清楚为什么同样的东西不能用于boilerpipe。我正在尝试基本上从JRuby中执行与此Java等效的操作:URLurl=newURL("http://www.example.com/some-location/index.html");Stringtext=ArticleExtractor.INSTANCE.getText(url);在JRuby中试过这个:require'java'url=java.net.URL.new("http://www
我只想对我一直在思考的这个问题有其他意见,例如我有classuser_controller和classuserclassUserattr_accessor:name,:usernameendclassUserController//dosomethingaboutanythingaboutusersend问题是我的User类中是否应该有逻辑user=User.newuser.do_something(user1)oritshouldbeuser_controller=UserController.newuser_controller.do_something(user1,user2)我
什么是ruby的rack或python的Java的wsgi?还有一个路由库。 最佳答案 来自Python标准PEP333:Bycontrast,althoughJavahasjustasmanywebapplicationframeworksavailable,Java's"servlet"APImakesitpossibleforapplicationswrittenwithanyJavawebapplicationframeworktoruninanywebserverthatsupportstheservletAPI.ht
这篇文章是继上一篇文章“Observability:从零开始创建Java微服务并监控它(一)”的续篇。在上一篇文章中,我们讲述了如何创建一个Javaweb应用,并使用Filebeat来收集应用所生成的日志。在今天的文章中,我来详述如何收集应用的指标,使用APM来监控应用并监督web服务的在线情况。源码可以在地址 https://github.com/liu-xiao-guo/java_observability 进行下载。摄入指标指标被视为可以随时更改的时间点值。当前请求的数量可以改变任何毫秒。你可能有1000个请求的峰值,然后一切都回到一个请求。这也意味着这些指标可能不准确,你还想提取最小/
HashMap中为什么引入红黑树,而不是AVL树呢1.概述开始学习这个知识点之前我们需要知道,在JDK1.8以及之前,针对HashMap有什么不同。JDK1.7的时候,HashMap的底层实现是数组+链表JDK1.8的时候,HashMap的底层实现是数组+链表+红黑树我们要思考一个问题,为什么要从链表转为红黑树呢。首先先让我们了解下链表有什么不好???2.链表上述的截图其实就是链表的结构,我们来看下链表的增删改查的时间复杂度增:因为链表不是线性结构,所以每次添加的时候,只需要移动一个节点,所以可以理解为复杂度是N(1)删:算法时间复杂度跟增保持一致查:既然是非线性结构,所以查询某一个节点的时候
目录前言滤波电路科普主要分类实际情况单位的概念常用评价参数函数型滤波器简单分析滤波电路构成低通滤波器RC低通滤波器RL低通滤波器高通滤波器RC高通滤波器RL高通滤波器部分摘自《LC滤波器设计与制作》,侵权删。前言最近需要学习放大电路和滤波电路,但是由于只在之前做音乐频谱分析仪的时候简单了解过一点点运放,所以也是相当从零开始学习了。滤波电路科普主要分类滤波器:主要是从不同频率的成分中提取出特定频率的信号。有源滤波器:由RC元件与运算放大器组成的滤波器。可滤除某一次或多次谐波,最普通易于采用的无源滤波器结构是将电感与电容串联,可对主要次谐波(3、5、7)构成低阻抗旁路。无源滤波器:无源滤波器,又称
最近在学习CAN,记录一下,也供大家参考交流。推荐几个我觉得很好的CAN学习,本文也是在看了他们的好文之后做的笔记首先是瑞萨的CAN入门,真的通透;秀!靠这篇我竟然2天理解了CAN协议!实战STM32F4CAN!原文链接:https://blog.csdn.net/XiaoXiaoPengBo/article/details/116206252CAN详解(小白教程)原文链接:https://blog.csdn.net/xwwwj/article/details/105372234一篇易懂的CAN通讯协议指南1一篇易懂的CAN通讯协议指南1-知乎(zhihu.com)视频推荐CAN总线个人知识总
深度学习部署:Windows安装pycocotools报错解决方法1.pycocotools库的简介2.pycocotools安装的坑3.解决办法更多Ai资讯:公主号AiCharm本系列是作者在跑一些深度学习实例时,遇到的各种各样的问题及解决办法,希望能够帮助到大家。ERROR:Commanderroredoutwithexitstatus1:'D:\Anaconda3\python.exe'-u-c'importsys,setuptools,tokenize;sys.argv[0]='"'"'C:\\Users\\46653\\AppData\\Local\\Temp\\pip-instal
遍历文件夹我们通常是使用递归进行操作,这种方式比较简单,也比较容易理解。本文为大家介绍另一种不使用递归的方式,由于没有使用递归,只用到了循环和集合,所以效率更高一些!一、使用递归遍历文件夹整体思路1、使用File封装初始目录,2、打印这个目录3、获取这个目录下所有的子文件和子目录的数组。4、遍历这个数组,取出每个File对象4-1、如果File是否是一个文件,打印4-2、否则就是一个目录,递归调用代码实现publicclassSearchFile{publicstaticvoidmain(String[]args){//初始目录Filedir=newFile("d:/Dev");Datebeg