本文地址: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运算符实现。创建数组通过两个途径:

(1) 数组声明后用new运算符创建,语法格式:

数组变量 = new 类型[长度];

(2) 数组声明时用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--数据类型、数组的更多相关文章

  1. Java学习笔记2——数据类型和转换

    前提知识: 1字节=8bit:1bit以一个二极管表示,代表2个状态(0或者1):2bit代表22即4种状态(00,01,10,11),8bit即是28即256种状态,16bit即是65536种状态. ...

  2. Java学习笔记三——数据类型

    前言 Java是强类型(strongly typed)语言,强类型包含两方面的含义: 所有的变量必须先声明后使用: 指定类型的变量只能接受预支匹配的值. 这意味着每一个变量和表达式都有一个在编译时就确 ...

  3. 【原】Java学习笔记003 - 数据类型

    package cn.temptation; public class Sample01 { public static void main(String[] args) { System.out.p ...

  4. Java学习笔记51:数组转ArrayList和ArrayList转数组技巧

    ArrayList转数组: public class Test { public static void main(String[] args) { List<String> list = ...

  5. Java学习笔记3(数组)

    1.数组的定义: 第一种: public class ArrayDemo{ public static void main(String[] args){ //定义数组 int [] arr = ne ...

  6. Java 学习笔记 二维数组和对象数组

    定义二维数组 int[][] a = new int[4][5]; 可以不指定列数 int[][] a = new int[4][]; 获取行 int i = a.length(); 如果使用第一个例 ...

  7. Java 学习笔记 判断一个数组是否有序

    思路 升序:每次比较数组中的两个数的时候,最大的数一定是前一个 降序: 每次比较数组中的两个数的时候,最小的数一定是前一个 Flag1和flag2都是假的时候,返回flase,否则,返回flase 代 ...

  8. java学习笔记(基础篇)—数组模拟实现栈

    栈的概念 先进后出策略(LIFO) 是一种基本数据结构 栈的分类有两种:1.静态栈(数组实现) 2.动态栈(链表实现) 栈的模型图如下: 需求分析 在编写代码之前,我习惯先对要实现的程序进行需求分析, ...

  9. java学习笔记04--数组

    java学习笔记04--数组 数组复制的方法是使用System类提供的arraycopy()方法,其语法如下: System.arraycopy(Object src, int srcPos, Obj ...

  10. Java学习笔记之---方法和数组

    Java学习笔记之---方法与数组 (一)方法 (1)什么是方法? 方法是解决一类问题的步骤的有序组合 方法包含于类或对象中 方法在程序中被创建,在其他地方被引用 (2)方法的优点 使程序变得更简短而 ...

随机推荐

  1. [BZOJ4521][CQOI2016]手机号码(数位DP)

    4521: [Cqoi2016]手机号码 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 875  Solved: 507[Submit][Status ...

  2. JZYZOJ1525 HAOI2012道路 堆优化的dijkstra+pair

    From Tyvj Guest ☆[haoi2012]道路                 描述 Description     C国有n座城市,城市之间通过m条单向道路连接.一条路径被称为最短路,当 ...

  3. 【带修改的主席树】BZOJ1901-Dynamic Rankings

    稍后整理笔记.这题数据范围好像有点问题? #include<iostream> #include<cstdio> #include<cstring> #includ ...

  4. 课堂实验-Bag

    这次的课堂实验比较简单,但尴尬的是竟然没有做出来,自己的代码能力下降了不少.IDEA的Junit测试出了问题.所以这次实验是和结对伙伴结对编程写的. public class Bag<T> ...

  5. [CSAcademy]A-Game

    题目大意: 给你一个只含字符'A'和'B'的串,A和B两人轮流对其中的子串染色,要求被染色的子串中不包含已经被染色的子串. 最后,如果一方染的'A'少,那么这一方胜: 如果双方染的'A'和'B'一样多 ...

  6. [bzoj1019][SHOI2008]汉诺塔 (动态规划)

    Description 汉诺塔由三根柱子(分别用A B C表示)和n个大小互不相同的空心盘子组成.一开始n个盘子都摞在柱子A上,大的在下面,小的在上面,形成了一个塔状的锥形体. 对汉诺塔的一次合法的操 ...

  7. PHP -- 简单表单提交

    网上看博文,一步步入门~~ 简单表单,简单提交 @_@!! <?php //php代码部分开始 echo "<html>"; echo "<hea ...

  8. ExtJs2.0学习系列(12)--Ext.TreePanel之第一式

    今天开始,我们就开始一起学习TreePanel了,道个歉,上篇的代码很乱阿. 我总是喜欢用最简单的例子开始,去理解最基本的使用方法,减少对i后面高级使用的干扰! TreePanel是继承自Panel, ...

  9. Django 中文显示

    Django中文显示: 1.如要在.py文件中显示中文,在文件首行加上:# -*- coding: utf-8 -*- 2.如要在html文件中显示中文,要将文件保存为UTF-8格式 3.在setti ...

  10. [Win32]创建模态窗口

    http://www.cnblogs.com/zplutor/archive/2011/02/20/1958973.html 在Win32编程中,如果要显示一个模态窗口,一般是先创建对话框模板,然后使 ...