总结

一. java 三大流程控制


1. 顺序控制

依次执行我们的代码。


2. 条件控制
int a = 0;
a. 目的 : 对程序执行,一些不可预知的流程,进行一个预先判断.
b. 条件:
条件具有真假的特性。而且只可能为真,或者为假。
c. java条件控制有四种手段:


(1)if语句
结构:


if(条件){
//实现我们的逻辑
}


(2)if...else语句
结构:


if(条件){
//实现我们的逻辑
}else{
//实现我们的逻辑
}


else后面之间跟我们的{//代码}


(3)if(条件)...else if(条件)...(接N个)...else


注意: a.else if(条件): 条件的约束,和我们前面说的if(条件),俩者是等价的.
      b.else if 可以有多个
 c.else 可以省略掉的, 但是即使没有匹配所有条件,我们依然建议必须有else,来保证 语句的完整和可读性.
 d.如果满足条件只需要执行一行代码,{}也是可以省略的,但是不建议这么做.
 

(4)switch case


结构:


switch(判断值){
case 值1:
break;
case 值2:
break;
.......
case 值n:
break;

default:
}




条件控制语句来说:
彼此可以嵌套使用的.




3. 表达式的类型:


int a = 5;
a*3 (结果15)
表达式的输出类型为表达式计算结果的类型.


------------------


double num = 1.5;
num * 4 (6.0, 表达式最终被当做的类型就是double类型)




课堂练习:


定义一个变量,保存年龄。 并且当年龄大于60岁,我们输出老年. 当年龄在 40 到 60 之间,我们输出中年. 当年龄在

18 - 40之间,我们输出少年. 如果小于18岁,输出未成年.




4.循环控制


a. while 循环


结构:
while(循环条件){
//循环实现的代码
}


b. do .. while循环
结构:


do{
//实现的代码
}while(循环的条件);


c. for 循环
使用率最高的;


结构:


for(循环变量初始化 ;循环条件判断; 循环变量的改变){
//循环需要实现的逻辑
}


d. foreach 循环(不是一个常规的java提供的循环的方式,他只是java提供的一种语法糖)
foreach: 对一种循环方式的命名,常规循环的简化方式. 
         语法糖: 针对基本的语法,提供了一种简化的实现方式.
 
补充知识点:


俩个关键字: 应用到循环控制中,continue的含义是跳出当次的循环,break的含义是跳出整个循环


continue:
在循环的代码体中,如果遇到continue, 则会跳出当次循环,循环体内continue之后的代码都不会执行,并且循环变量进行一次改变操作,
之后再次进行条件判断,如果满足条件,则进入循环,否则直接结束循环; 跳出的仅是continue外层直接包裹的循环.


break:
在循环的代码体中,如果遇到break,则会跳出本循环代码块,break后的代码不会执行。并且整个循环的过程结束。
break后退出的循环也是直接包围break的循环。
 
课堂练习:


求1-50(俩边都闭区间), 所有偶数的和.
最终输出结果.


求1-100自然数,其中所有偶数的和,所有奇数的和,并且求所有偶数的和与所有奇数的和的差.




循环的嵌套:


System.out.println("*"); //输出,会默认换行
System.out.print("*"); //输出,不会换行


*****
*****
*****
*****
*****


*
**
***
****
*****


课堂练习:


输出:
*****
****
***
**
*




4.数组


阶段性关键字总结:


public,class,static,void,int,boolean,char,byte,long,short,double,float,final.


new:
用来创建一个对象。


定义:


数组保存元素的类型 [] 数组变量的名称 = new 数组保存元素的类型[元素的数量];


数组元素的访问: index(数组保存元素的索引) , 从0开始(length-1)


数组来说,如果初始化一个数组,但是并没有保存任何的值,那么数组中会存放一些默认的值:
byte,short,int,long: 0
float,double:0.0
boolean: false
char: ''




数组对象中有一个变量length,能够让我们拿到数组的长度.


 
课堂练习:


定义一个保存5个整形的数组,依次赋值为 1--5.

最终再依次打印出数组保存的每个元素(要求打印的时候按照倒序)


一. 数组


1.数组定义: 用来一次性保存多个相同类型元素的这样一种数据结构.


2.维度上分:


一维数组,多维数组.


一维数组:


3.声明:
类型 [] 数组变量名称
int [] arr;
或者
int arr[];
俩种形式都可以,而且没有任何的区别,不过建议我们采取第一种方式.




4.初始化:


动态初始化:
我们在定义一个数组和对数组进行赋值的操作,我们分开来执行。


静态初始化:
我们在定义一个数组的同时,进行数组的初始化


//动态初始化
int [] arr = new int[3];

arr[0] = 1;
arr[1] = 2;
arr[2] = 3;

//静态初始化
int []arr1 = new int[]{1,2,3};
int []arr2 = {1,2,3,4};

new:
用来初始化一个对象。


数组里面注意事项:
a. 数组长度一旦指定,是永远不可以改变的。
b. 数组保存的元素类型一旦指定,也是不可以改变,并且只能保存该类型的元素


5.length:
int a[] = new in[3];
int size = a.length;


6.数组元素的访问
arr[index]: index表示数组元素的索引,注意索引是从0到length-1.
arr[1]:访问第二个元素


index: 可以是常量,也可以是表达式。


课堂练习:
第一个一个保存10个整形元素的一维数组,其中值为1到10,我们分别求 这十个数的和,以及十个数的平均值,
以及俩俩相邻的差,最终的和。


1,2,3,4,5,6 


for(int i=0;i<arr.length-1;i++){
   arr[i] - arr[i+1];
}




二维数组:


声明:
类型 [][] 数组名称;
int [][] arr;


初始化:
a.动态初始化
int [][]arr = new int[3][];




b.静态初始化
int [][]arr = {{1,2,3},{2,3,4,5}};


length:
这个属性拿到二维数组的长度。




二. 方法


定义: 实现一个功能的代码片段的封装。


[修饰符...] 返回值类型 方法名称(形参的列表){
//方法中实现的逻辑
}


形参列表: 方法接收外部传入的数据的接收媒介.
返回值: 方法执行结束之后,返回的值的类型。
如果方法不需要返回任何的值,那么我们的方法返回类型写作void.
在方法里返回一个值,需要用到 return. 


形参列表:
当我们定义了一个方法之后,去调用方法的时候,一定要注意我们传递给方法的入参的类型和数量,一定要一一对应。


唯一确定一个方法:
关注点:
a.方法名是否一致
b.形参列表的所有参数类型和数量是否一致。 对于形参变量的命名,完全是没有关系的.
c.返回值的类型
  可以是基本类型,也可以是引用类型。
  
注意:


a.一旦明确指定了方法的返回类型(非void),那么一定要保证最终方法可以成功的返回我们对应的返回类型的数据.
b.关于void返回类型
如果我们不主动的添加return语句,在执行的时候,也会帮我们自动添加return.我们在实现void类型的方法的时候,主动添加一个
return也是没有问题。 


java预编译的特点.




方法参数的传递:


方法参数的传递来说,基本类型传递的是值。对于引用类型,传递的是引用.(传递的是地址)







类:


用户类: 包含订单类(用户通过订单类中的方法进行下单)
   


商品类 
  电子类商品
  生活用品类商品
  家电类商品


订单类


一. 关于变量的作用域:


成员变量:
类的属性


局部变量:
方法中定义的变量或者是方法的形式参数。


对于java语言来说,作用域控制是通过块来控制的.
块的概念: 一对{} 包裹,该代码片段就称为 一块.


对于某个块内定义的变量:
a.对于当前的块,不能再定义同名的变量,即使类型不同也不行。
b.对于当前的块,定义了某个变量,在块外不能够访问到块中定义的变量


如果存在块的嵌套:
那么外层块定义的变量,在内层块中是可以访问到的.






二. 构造方法(构造器)


1.类中特殊的方法,对于定义来讲,它的方法名必须和类名一模一样,并且不返回任何的值,主要不能添加void.
2.在new(创建一个对象的时候),一定会去调用它的构造方法。 但是如果我们没有自己添加自己定义的构造器的话,编译器会帮我们
  偷偷的添加一个默认的构造器:
  
  类名(){
  
  }
  
  如果我们主动添加一个默认的构造器,那么在创建对象的时候,通过new 类名(); 会调用我们自己添加的默认构造器.
  
3.当我们主动添加了一个包含参数列表的构造器,并且没有主动添加默认的构造器,则再通过new 类名(); 就会遇到编译问题.


三. 方法重载 overload
 
1. 对于同名的方法,具有不相同的参数列表,我们在访问的时候,通过调用方法传入不同的参数列表,就可以找到我们特定的方法。


2. 当我们定义多个重载的方法的时候,在编译阶段的话,编译器可以根据我们方法形式参数数量以及类型来区别不同的方法,执行阶段可以
   根据我们调用的时候传入的参数列表, 仅仅拥有不同的返回值类型,是不被视为重载的。
   
   
   
四. 类的继承


 子类继承或者说派生自父类。子类可以享有父类的方法。在初始化一个子类对象的时候,调用其中的方法,如果该方法中在父类也有定义,
 并且参数列表不同,则调用到的是子类特有的方法。否则调用的是父类方法。
 注意:如果仅仅是他们的返回值类型不同,则会出现编译错误。
 
 
   












  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
,发送类别,概率,以及物体在相机坐标系下的xyz.zip目标检测(Object Detection)是计算机视觉领域的一个核心问题,其主要任务是找出图像中所有感兴趣的目标(物体),并确定它们的类别和位置。以下是对目标检测的详细阐述: 一、基本概念 目标检测的任务是解决“在哪里?是什么?”的问题,即定位出图像中目标的位置并识别出目标的类别。由于各类物体具有不同的外观、形状和姿态,加上成像时光照、遮挡等因素的干扰,目标检测一直是计算机视觉领域最具挑战性的任务之一。 二、核心问题 目标检测涉及以下几个核心问题: 分类问题:判断图像中的目标属于哪个类别。 定位问题:确定目标在图像中的具体位置。 大小问题:目标可能具有不同的大小。 形状问题:目标可能具有不同的形状。 三、算法分类 基于深度学习的目标检测算法主要分为两大类: Two-stage算法:先进行区域生成(Region Proposal),生成有可能包含待检物体的预选框(Region Proposal),再通过卷积神经网络进行样本分类。常见的Two-stage算法包括R-CNN、Fast R-CNN、Faster R-CNN等。 One-stage算法:不用生成区域提议,直接在网络中提取特征来预测物体分类和位置。常见的One-stage算法包括YOLO系列(YOLOv1、YOLOv2、YOLOv3、YOLOv4、YOLOv5等)、SSD和RetinaNet等。 四、算法原理 以YOLO系列为例,YOLO将目标检测视为回归问题,将输入图像一次性划分为多个区域,直接在输出层预测边界框和类别概率。YOLO采用卷积网络来提取特征,使用全连接层来得到预测值。其网络结构通常包含多个卷积层和全连接层,通过卷积层提取图像特征,通过全连接层输出预测结果。 五、应用领域 目标检测技术已经广泛应用于各个领域,为人们的生活带来了极大的便利。以下是一些主要的应用领域: 安全监控:在商场、银行
目标检测(Object Detection)是计算机视觉领域的一个核心问题,其主要任务是找出图像中所有感兴趣的目标(物体),并确定它们的类别和位置。以下是对目标检测的详细阐述: 一、基本概念 目标检测的任务是解决“在哪里?是什么?”的问题,即定位出图像中目标的位置并识别出目标的类别。由于各类物体具有不同的外观、形状和姿态,加上成像时光照、遮挡等因素的干扰,目标检测一直是计算机视觉领域最具挑战性的任务之一。 二、核心问题 目标检测涉及以下几个核心问题: 分类问题:判断图像中的目标属于哪个类别。 定位问题:确定目标在图像中的具体位置。 大小问题:目标可能具有不同的大小。 形状问题:目标可能具有不同的形状。 三、算法分类 基于深度学习的目标检测算法主要分为两大类: Two-stage算法:先进行区域生成(Region Proposal),生成有可能包含待检物体的预选框(Region Proposal),再通过卷积神经网络进行样本分类。常见的Two-stage算法包括R-CNN、Fast R-CNN、Faster R-CNN等。 One-stage算法:不用生成区域提议,直接在网络中提取特征来预测物体分类和位置。常见的One-stage算法包括YOLO系列(YOLOv1、YOLOv2、YOLOv3、YOLOv4、YOLOv5等)、SSD和RetinaNet等。 四、算法原理 以YOLO系列为例,YOLO将目标检测视为回归问题,将输入图像一次性划分为多个区域,直接在输出层预测边界框和类别概率。YOLO采用卷积网络来提取特征,使用全连接层来得到预测值。其网络结构通常包含多个卷积层和全连接层,通过卷积层提取图像特征,通过全连接层输出预测结果。 五、应用领域 目标检测技术已经广泛应用于各个领域,为人们的生活带来了极大的便利。以下是一些主要的应用领域: 安全监控:在商场、银行
目标检测(Object Detection)是计算机视觉领域的一个核心问题,其主要任务是找出图像中所有感兴趣的目标(物体),并确定它们的类别和位置。以下是对目标检测的详细阐述: 一、基本概念 目标检测的任务是解决“在哪里?是什么?”的问题,即定位出图像中目标的位置并识别出目标的类别。由于各类物体具有不同的外观、形状和姿态,加上成像时光照、遮挡等因素的干扰,目标检测一直是计算机视觉领域最具挑战性的任务之一。 二、核心问题 目标检测涉及以下几个核心问题: 分类问题:判断图像中的目标属于哪个类别。 定位问题:确定目标在图像中的具体位置。 大小问题:目标可能具有不同的大小。 形状问题:目标可能具有不同的形状。 三、算法分类 基于深度学习的目标检测算法主要分为两大类: Two-stage算法:先进行区域生成(Region Proposal),生成有可能包含待检物体的预选框(Region Proposal),再通过卷积神经网络进行样本分类。常见的Two-stage算法包括R-CNN、Fast R-CNN、Faster R-CNN等。 One-stage算法:不用生成区域提议,直接在网络中提取特征来预测物体分类和位置。常见的One-stage算法包括YOLO系列(YOLOv1、YOLOv2、YOLOv3、YOLOv4、YOLOv5等)、SSD和RetinaNet等。 四、算法原理 以YOLO系列为例,YOLO将目标检测视为回归问题,将输入图像一次性划分为多个区域,直接在输出层预测边界框和类别概率。YOLO采用卷积网络来提取特征,使用全连接层来得到预测值。其网络结构通常包含多个卷积层和全连接层,通过卷积层提取图像特征,通过全连接层输出预测结果。 五、应用领域 目标检测技术已经广泛应用于各个领域,为人们的生活带来了极大的便利。以下是一些主要的应用领域: 安全监控:在商场、银行
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值