java第三周学习
这一周学习的是java数组面向对象
数组中存放的数据的类型:既可以是基本数据类型也可以是引用数据类型。
数组的定义方式:
1 数据类型[] 数组名;
2 数据类型 数组名[];
数组的初始化:
1.静态初始化:
结构:
数据类型[] 数组名 = {元素1,元素2,元素3,......};
数据类型 数组名[] = {元素1,元素2,元素3,......};
2.动态初始化
数据类型[] 数组名 = new 数据类型[指定数组的元素个数];
取值:数据类型 变量名 = 数组名[元素下标]
赋值(修改): 数组名[元素下标] = 值
使用注意点:
如果是静态初始化数组,需要将f定义和初始化一起完成。
数组的遍历:
1.lenght 获取的数组的长度(元素的个数)
2.通过循环遍历数组中的元素。
示例:
For (int a =0;a<arr.lenght;a++)
{
System.out.println(arr[a])
}
For (int a : arr)
{
System.out.println(a);
}
数组的排序操作
选择排序有又可以成为直接排序: 将数组中的每一个元素依次和数组中其他的元素做比较,将符合条件的进行交换。
示例: 定义一个int数组,想将数组中的最大值移动到首位
for(int j = 0 ;j<arr.length-1;j++){
for(int i = j+1;i<=arr.length-1;i++){
if(arr[i] > arr[j]){
int temp = arr[j];
arr[j] = arr[i];
arr[i] = temp;
}
}
}
for(int a : arr){}System.out.println(a);}
冒泡排序
冒泡排序:将数组中相邻的两个数依次做比较,将大的数放在最后面
示例: 通过冒泡排序操作, 找出最大的值放在最后面
public static void main(String[] args)
{
int[] arr = {2,10,13,9,4,8,3,11};
for(int j = arr.length-1;j>0;j--){ //0-5
for(int i = 0;i<j;i++){
if(arr[i] > arr[i+1]){
int temp = arr[i];
arr[i] = arr[i+1];
arr[i+1] = temp;
}
}
for(int i = 0;i<arr.length;i++){
System.out.println(arr[i]);
}
}
Array类
常用的方法:
- Sort(int[]a) 升序排列
- toString(int[]a) 将数组以一个字符串打印出来
- binarySearch(int[]a.int key) 用二分法查找数据
Sort(int[]a)方法示例;
Int []arr={1.3.4.56.5}
Arrays.sort.(arr);
遍历数组:fo(int i :arr){System.out.println(i);}
toString(int[]a) 方法示例;
Int []arr={1.3.4.56.5}
遍历数组:System.out.println(Arrays.toString(arr));
binarySearch(int[]a.int key)方法示例;
Int []arr={1.3.4.56.5}
Arrays.sort.()arr;
Int a=Arrys.binarySearch(arr,3) 3 是需要查找的数字
a = 返回的是找到的数字的下标
如果没有找到返回的将是一个负数
Java 多维数组
一维数组: int a []={1,2,3,4}
二维数组:int a [][]={{1,2,3,4}{1,2,3,4}}
三维数组:int a [][][]={{1,2,3,4}{1,2,3,4}{1,2,3,4}}
多维数组:int a [][][]…….= {{1,2,3,4}{1,2,3,4}{1,2,3,4},………..}
多维数组就是数组中的数组
比如:二维数组中的元素是一维数组
定义方式:
Int[一维数组][二维数组]……..数组名
初始化方式
静态:int a [][]={{},{},{}}
动态:int a [][]=new int[3][4]
多维数组的取值和赋值
分为静态初始化数组取值赋值和动态初始化取值
Java 面向对象
概念
面向对象:是以事物为中心的编程过程.
对象的组成:属性和方法
类: 通过对象的共有特点和行为所抽象出来的模子。类是没有具体的行为和属性。
对象: 就是类的一个具体实例。通过属性和方法来描述的。
1.Java 中定义类
通过关键字 class , java编程是以类为基本单元。
定以类的格式:
class 类名 {
属性(对象的特征),成员变量
行为(方法)
方法的定义格式:
返回值类型: 指的就是数据类型。 void ---> 空类型
参数列表 : 可有可无。
返回值类型 方法名 (参数列表){
}
}
2.创建对象:
Java 中创建对象都是通过new对象来完成
结构 :
new 类的名字();
需要定义一个该类型的变量来接收
类的类型 对象名 = new 类的名字();
赋值属性:
对象名.属性名字 = 值;
取值:
数据类型 变量名 = 对象名.属性名
方法的调用:
对象名.方法名();
3.类中方法的定义和使用
一.java 中通过参数分类
1.有参定义法: 小括号中的参数可以有一个或者多个,多个参数之间用”,隔开
2.无参定义法: 小括号中不要任何东西。
二.java中通过返回值类型分类
1.有返回值型: 方法体后面加return
2.无返回值型: void 空类型
今天就写到这里吧,一周学习的东西挺多的,好多东西的具体应用还没有完全理解透,以后慢慢的再练习!
java第三周学习的更多相关文章
- 20165210 Java第三周学习总结
20165210 Java第三周学习总结 教材学习内容总结 - 第四章学习总结 编程语言的几个发展阶段: 面向机器语言 面向过程语言 面向对象语言 类: 类声明: class People { ... ...
- 20145304 Java第三周学习报告
20145304 <Java程序设计>第三周学习总结 教材学习内容总结 1.定义类: 类定义时使用class关键词,建立实例要使用new关键词. 代码如下: /*定义类 书上例子 衣服的型 ...
- JAVA第三周学习总结
20175303 2018-2019-2 <Java程序设计>第三周学习总结 教材学习内容总结 •编程语言的发展分为三个阶段,分别是:面向机器,面向过程,面向对象的语言.Java属于面向对 ...
- JAVA 第三周学习总结
20175308 2018-2019-2 <Java程序设计>第三周学习总结 教材学习内容总结 本周的学习内容为整个第四章的内容,学习中感觉知识点既多又杂,故在总结时尽量选用重要的或高度概 ...
- 20165221 JAVA第三周学习心得
知识点回顾 类与对象学习总结 类:java作为面向对象型语言具有三个特性:①封装性.②继承性.③多态性.java中类是基本要素,类声明的变量叫对象.在类中定义体的函数题叫方法. 类与程序的基本结构: ...
- Java第三周学习日记
Day01 1.线程 进程:进程就是正在运行的应用程序.进程负责了内存空间的划分. 线程:一个进程中的代码是由线程去执行的,线程也就是其中一个执行路径. 多线程:一个进程中有多个线程可以同时执行任务. ...
- 201521123093 java 第三周学习总结
1.本周学习总结 初学面向对象,会学习到很多碎片化的概念与知识.尝试学会使用思维导图将这些碎片化的概念.知识组织起来.请使用纸笔或者下面的工具画出本周学习到的知识点.截图或者拍照上传. 本周学习总结: ...
- 20165220 Java第三周学习总结
1.教材学习内容总结 类与对象 类与对象的关系:要产生对象必须先定义类,类是对象的设计图,对象是类的实例 为个别对象的数据成员指定值的方式是:对象.对象成员 注意“一类一文件” 类在定义时要使用关键词 ...
- 20165326 java第三周学习笔记
纸质学习笔记 代码托管
随机推荐
- windows7 x64下maven安装和配置
http://maven.apache.org/download.cgi下载maven 环境配置 验证配置是否成功 本地仓库配置 这是原来的配置文件: 更改为: link 离线安装 eclipse m ...
- ios native工程集成react-native的demo
react-native看到了给现有工程添加react-native环境的时候碰到一个问题: 如何往工程中添加 package.json文件,以及node_modules是怎么来的? 我开始的时候以为 ...
- Android Studio使用时源码到处报红色警告,运行时又没错
转载地址:http://www.07net01.com/program/2016/04/1452749.html [摘要:正在AS上开辟时,碰到那个题目,翻开全部的Java源文件,右边一起标赤色,找没 ...
- Android编码规范05
编码逻辑规范总结: 1.避免使用多个类放在一个文件里,除非是一次性使用的内部类 2.一个方法代码长度最好不要超过35行 3.原则上尽量不要修改自动生成的文件,如R文件 4.Final String 取 ...
- java中IO流异常处理
import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import ja ...
- 第二章作业-第3题(markdown格式)-万世想
第3题题目是: 完成小组的"四则运算"项目的需求文档(使用Markdown写文档),尝试同组成员在各自PC上修改同一文档后,如何使用Git命令完成GitHub上的文档的更新,而不产 ...
- mysql半同步复制问题排查
1.问题背景 默认情况下,线上的mysql复制都是异步复制,因此在极端情况下,主备切换时,会有一定的概率备库比主库数据少,因此切换后,我们会通过工具进行回滚回补,确保数据不丢失.半同步复制则 ...
- 萌新笔记——C++里创建 Trie字典树(中文词典)(三)(联想)
萌新做词典第三篇,做得不好,还请指正,谢谢大佬! 今天把词典的联想做好了,也是比较low的,还改了之前的查询.遍历等代码. Orz 一样地先放上运行结果: test1 ID : char : 件 w ...
- UVA10325 The Lottery(容斥原理)
题意: 给n,m,和m个数(k1~km).求1~n中有多少个数不是(k1~km)中任意一数的倍数. 题解: 容斥模板题.反面考虑,a的倍数有n/a个:既是a,也是b的倍数,即lcm(a,b)的倍数有n ...
- [KMP]【学习笔记】
Oulipo Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 36916 Accepted: 14904 Descript ...