java学习笔记2--数据类型、数组
本文地址:http://www.cnblogs.com/archimedes/p/java-study-note2.html,转载请注明源地址。
1.数据类型
Java数据类型有:
原始数据类型(Primitive Data Types )
引用类型(reference type )
Java原始数据类型又称基本数据类型,它说明了在程序中所能表示的基础数据的种类,通常有8种。引用类型包括类、接口等,具体内容将在后面文章中介绍。
Java原始(基本)数据类型:
boolean 布尔型, 只有真(true)与假(false)
byte 8位符号整数, 取值范围-128~+127
short 16位符号整数, 取值范围-32768~+32767
char 16位字符, Unicode字符集,字符码数值范围: 0(‘\u0000’ )~65535(‘\uffff’)。
int 32位符号整数, 取值范围:-2147483648~+2147483647
long 64位符号整数, 取值范围:-9223372036854775808~+9223372036854775807
float 32位单精度浮点数,使用IEEE754标准。
double 64位双精度浮点数,使用IEEE754标准。
Java原始数据类型变量的默认值

Java原始数据类型占用的位数

2、%(求模)运算符
op1 % op2
计算op1被op2除的余数。
说明:
求模运算时op1与op2必须是整数。
如果op1为负数,op2为正数,结果为负。
如果op1为正数,op2为负数,结果为正。
如果op1为正数,op2为正数,结果为正。
如果op1为负数,op2为负数,结果为负。
跑个程序吧:
public class test
{
public static void main(String args[]) {
System.out.println("4 % 3 = " + 4 % 3);
System.out.println("-4 % 3 = " + (-4) % 3);
System.out.println("-4 % -3 = " + (-4) % (-3));
System.out.println("4 % -3 = " + 4 % (-3));
}
}
运行结果如下:
4 % 3 = 1
-4 % 3 = -1
-4 % -3 = -1
4 % -3 = 1
3、强格式的for语句:
对于数组(Arrays)和集合(Collections)的迭代,有一种更紧凑易读的for语句形式。语法格式:
for(元素型变量:数组型或集合型变量){
语句;
}
跑个程序吧:
public class Main
{
public static void main(String args[]) {
int sum = 0;
int[] numbers = {1,2,3,4,5,6,7,8,9,10};
for (int item : numbers) {
sum += item;
}
System.out.println("Sum is: " + sum);
}
}
4、一维数组
一维数组的声明语法格式:
数组类型 数组名称;
或
类型[] 名称;
例如: int[] anArray; String[] agrs;
创建一维数组
声明的数组型变量是引用型变量,因此数组声明后只有通过创建才能够使用。创建数组要使用new运算符实现。创建数组通过两个途径:
数组变量 = new 类型[长度];
类型[] 数组变量 = new 类型[长度];
int[] aArray;
aArray = new int[100]; float[] fArray;
fArray = new float[35]; double[] dData = new double[23];
String[] sTitle = new String[15];
跑个程序吧:
public class test
{
public static void main(String args[]) {
double[] dRandom;
int i = 0;
dRandom = new double[5];
while( i < 5) {
dRandom[i] = 9.0 * Math.random();
System.out.println("dRandom["+ i +"]=" + dRandom[i]);
i++;
}
}
}
运行结果如下:
dRandom[0]=7.513923470155991
dRandom[1]=3.3304886355341017
dRandom[2]=2.2258372149369214
dRandom[3]=4.450285565380552
dRandom[4]=3.0354964312542174
数组复制的方法是使用System类提供的arraycopy()方法,其语法如下:
System.arraycopy(Object src, int srcPos, Object dest, int destPos, int length);
System.arraycopy(源数组,源数组中的起始位置,目标数组,目标数据中的起始位置,要复制的数组元素的数量);
跑个程序吧:
public class test {
public static void main(String args[]){
int arr1[] = {1,2,3,4,5};
int arr2[] = new int[5];
System.arraycopy(arr1, 0, arr2, 0, 5);
for (int i = 0; i < arr2.length; i++) {
System.out.println(arr2[i]);
}
}
}
5、Arrays类
对数组的一些基本操作,像排序、搜索与比较等都是很常见的。在java中提供了Array是类可以协助您作这几个操作,Array是类位于java.util包中,他提供了几个方法可以直接使用。
sort() 帮助您对指定的数组排序,所使用的是快速排序法
binarySearch() 让您对已排序的数组进行二元搜索,如果找到指定的值就返回该值所在的索引,否则就返回负值
fill() 当您配置一个数组之后,会依据数据类型来给定默认值。例如整数数组就初始值为0,可以使用Arrays.fill()方法将所有的元素设置为指定的值
equals() 比较两个数组中的元素值是否全部相等,如果是将返回true,否则返回false
import java.util.Scanner;
import java.util.Arrays;
public class test {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in); int[] arr = { 93, 5, 3, 55, 57, 7, 2, 73, 41, 91 }; System.out.print("排序前: ");
for (int i = 0; i < arr.length; i++){
System.out.print(arr[i] + " ");
}
System.out.println(); Arrays.sort(arr); System.out.print("排序后: ");
for (int i = 0; i < arr.length; i++){
System.out.print(arr[i] + " ");
}
System.out.print("\n请输入搜索值:");
int key = scanner.nextInt();
int find = -1;
if ((find = Arrays.binarySearch(arr, key)) > -1) {
System.out.println("找到值于索引 " + find + " 位置");
} else
System.out.println("找不到指定值");
}
}
执行结果如下:
排序前: 93 5 3 55 57 7 2 73 41 91
排序后: 2 3 5 7 41 55 57 73 91 93
请输入搜索值:5
找到值于索引 2 位置
下面使用Arrays来进行数组的填充与比较:
import java.util.Arrays;
public class test {
public static void main(String[] args) {
int[] arr1 = new int[10];
int[] arr2 = new int[10];
int[] arr3 = new int[10]; Arrays.fill(arr1, 5);
Arrays.fill(arr2, 5);
Arrays.fill(arr3, 10); System.out.print("arr1: ");
for (int i = 0; i < arr1.length; i++){
System.out.print(arr1[i] + " ");
}
System.out.println("\narr1 = arr2 ? " + Arrays.equals(arr1, arr2));
System.out.println("arr1 = arr3 ? " + Arrays.equals(arr1, arr3));
}
}
执行后的结果如下:
arr1: 5 5 5 5 5 5 5 5 5 5
arr1 = arr2 ? true
arr1 = arr3 ? false
java学习笔记2--数据类型、数组的更多相关文章
- Java学习笔记2——数据类型和转换
前提知识: 1字节=8bit:1bit以一个二极管表示,代表2个状态(0或者1):2bit代表22即4种状态(00,01,10,11),8bit即是28即256种状态,16bit即是65536种状态. ...
- Java学习笔记三——数据类型
前言 Java是强类型(strongly typed)语言,强类型包含两方面的含义: 所有的变量必须先声明后使用: 指定类型的变量只能接受预支匹配的值. 这意味着每一个变量和表达式都有一个在编译时就确 ...
- 【原】Java学习笔记003 - 数据类型
package cn.temptation; public class Sample01 { public static void main(String[] args) { System.out.p ...
- Java学习笔记51:数组转ArrayList和ArrayList转数组技巧
ArrayList转数组: public class Test { public static void main(String[] args) { List<String> list = ...
- Java学习笔记3(数组)
1.数组的定义: 第一种: public class ArrayDemo{ public static void main(String[] args){ //定义数组 int [] arr = ne ...
- Java 学习笔记 二维数组和对象数组
定义二维数组 int[][] a = new int[4][5]; 可以不指定列数 int[][] a = new int[4][]; 获取行 int i = a.length(); 如果使用第一个例 ...
- Java 学习笔记 判断一个数组是否有序
思路 升序:每次比较数组中的两个数的时候,最大的数一定是前一个 降序: 每次比较数组中的两个数的时候,最小的数一定是前一个 Flag1和flag2都是假的时候,返回flase,否则,返回flase 代 ...
- java学习笔记(基础篇)—数组模拟实现栈
栈的概念 先进后出策略(LIFO) 是一种基本数据结构 栈的分类有两种:1.静态栈(数组实现) 2.动态栈(链表实现) 栈的模型图如下: 需求分析 在编写代码之前,我习惯先对要实现的程序进行需求分析, ...
- java学习笔记04--数组
java学习笔记04--数组 数组复制的方法是使用System类提供的arraycopy()方法,其语法如下: System.arraycopy(Object src, int srcPos, Obj ...
- Java学习笔记之---方法和数组
Java学习笔记之---方法与数组 (一)方法 (1)什么是方法? 方法是解决一类问题的步骤的有序组合 方法包含于类或对象中 方法在程序中被创建,在其他地方被引用 (2)方法的优点 使程序变得更简短而 ...
随机推荐
- Java中的覆盖和隐藏以及final关键字
Java覆盖和隐藏 (1) 变量只能被隐藏(包括静态和非静态),不能被覆盖: (2) 可以用子类的静态变量隐藏父类的静态变量,也可以用子类的非静态变量隐藏父类的静态变量,也可以用非最终变量(final ...
- 机器寻径引导算法C#(最短路径表)
using System; using System.Collections; using System.Collections.Generic; using System.Linq; using S ...
- BZOJ1007 水平相交直线
按照斜率排序,我们可以想象如果你能看到大于等于三条直线那么他一定会组成一个下凸包,这样我们只需要判断如果当前这条直线与栈顶第二直线相交点相比于栈顶第二直线与栈顶直线相交点靠左那么他就不满足凸包性质. ...
- [POJ2749]Building roads(2-SAT)
Building roads Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 8153 Accepted: 2772 De ...
- 【并查集】【枚举倍数】UVALive - 7638 - Number of Connected Components
题意:n个点,每个点有一个点权.两个点之间有边相连的充要条件是它们的点权不互素,问你这张图的连通块数. 从小到大枚举每个素数,然后枚举每个素数的倍数,只要这个素数的某个倍数存在,就用并查集在这些倍数之 ...
- 【动态规划/多重背包问题】POJ2392-Space Elevator
方法同POJ1014-Dividing,唯一不同点在于每一种block有最大限定高度a,故要以a为关键字进行排序,使得最大高度小的在前,否则最大高度小的再后可能放不上去. #include<io ...
- Java并发(十四):并发工具类——CountDownLatch
先做总结: 1.CountDownLatch 是什么? CountDownLatch 允许一个或多个线程等待其他线程(不一定是线程,某个操作)完成之后再执行. CountDownLatch的构造函数接 ...
- poj 2001 trie
第一道trie 还需要写题来建立自己的代码习惯. #include <cstdio> #include <vector> #include <algorithm> ...
- USACO 2017 FEB Gold visitfj 最短路
题意 有一幅n*n的方格图,n <= 100,每个点上有一个值.从(1,1)出发,走到(n,n),只能走四联通.每走一步花费t,每走三步需要花费走完三步后到达格子的值.求最小花费的值. 拆点,d ...
- CDOJ 842 天下归晋 树状数组
天下归晋 Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://acm.uestc.edu.cn/#/problem/show/842 Descrip ...