Java环境搭建及语言基础

JRE和JDK

JRE:Java Runtime Environment,java运行环境。

JDK:Java Development Kit,java开发工具包。

使用JDK开发java程序,交给JRE运行。

JDK下载和安装

http://www.oracle.com/technetwork/java/javase/downloads/index.html

JDK的目录结构

目录/文件名 功能说明 
 bin  包含编译器、解释器等可执行文件
 include  编写JNDI等程序需要的C语言头文件
 jre  Java运行时环境
 lib  Java类库
 src.zip  核心API所有类的源文件

 

 

 

 

 

 

 bin中的主要工具(JDK常用命令) 

文件名 功能说明
javac.exe Java编译器,将Java源程序编译成字节码文件
java.exe Java解释器,执行字节码文件对应的Java类
javadoc.exe 根据Java源码及说明语句生成HTML文档
jar.exe 压缩文件,扩展名为JAR(Java Archive,Java归档),与Zip压缩文件格式相同
jdb.exe Java调试器,可以逐行执行程序,设置断点和检查变量
appletviewer.exe Applet应用程序浏览器

 

 

 

 

 

 

 

 

环境变量的配置

右击“我的电脑” —> “属性” —> “高级” —> “环境变量”,在“系统变量”里我们可以看到系统的各个环境变量的值。

  • JAVA_HOME:JDK的安装目录,Eclipse/NetBeans/Tomcat等软件就是通过搜索JAVA_HOME变量来找到并使用安装好的JDK。如C:\jdk1.7.0_02。

  • PATH:指定命令搜索路径,设置好PATH变量后,就可以在任何目录下执行javac/java等工具了。%JAVA_HOME%\bin;%JAVA_HOME%\jre\bin;

  • CLASSPATH:指定类搜索路径,JVM就是通过CLASSPATH来寻找类的。.;%JAVA_HOME%\lib;%JAVA_HOME%\lib\dt.jar;%JAVA_HOME%\lib\tools.jar;

为什么需要配置path?

  • 不把JDK的bin目录加到path的话,需要在JDK的bin目录下打开cmd命令窗口执行 javac/java 等JDK命令。
  • 配置好path后,可以在任何文件目录下打开cmd命令窗口成功运行java/javac等JDK命令,输入省事多了。

path也就是系统变量,它会告诉操作系统可执行文件(*.exe,*.bat)所在的路径。对于操作系统而言,当它要使用某个*.exe 时,会先从当前目录查找这个命令,如果查找不到,OS就会到path所设定的路径去查找该命令,然后执行。

什么时候需要配置classpath?

  • 当我们要在dos下编译运行java程序,如果用到第三方jar包,要让java解释器知道到哪里去找这个类,就需要在classpath中指定路径,否则会报错。【提示程序包不存在】
  • 或者手动加上jar包目录也是可以的:【比较麻烦不推荐】比如第三包jar包位于E:\Program SoftWare\Java目录下,那编译的时候就要执行:javac -classpath E:\Program SoftWare\Java\servlet-api.jar -d build\classes src\com\itheima\Test2.java

classpath是告诉java虚拟机(jvm)要使用或执行的*.class文件放在什么地方。

配置好后在任意目录下运行javac,java命令

C:\Users\Administrator\Desktop>javac
用法: javac <options> <source files>
其中, 可能的选项包括:
  -g                         生成所有调试信息
  -g:none                    不生成任何调试信息
  -g:{lines,vars,source}     只生成某些调试信息
  -nowarn                    不生成任何警告
  -verbose                   输出有关编译器正在执行的操作的消息
  -deprecation               输出使用已过时的 API 的源位置
  -classpath <路径>            指定查找用户类文件和注释处理程序的位置
  -cp <路径>                   指定查找用户类文件和注释处理程序的位置
  -sourcepath <路径>           指定查找输入源文件的位置
  -bootclasspath <路径>        覆盖引导类文件的位置
  -extdirs <目录>              覆盖所安装扩展的位置
  -endorseddirs <目录>         覆盖签名的标准路径的位置

临时配置

  • E:\>set 列出本机全部的环境变量。
  • E:\>set Path 列出环境变量Path的值。
  • E:\>set Path= 清空环境变量Path。
  • E:\>set Path= E:\jdk1.7.0_21 设置环境变量Path的值,只在当前dos命令行有效。
  • 在已有的目录添加新值。E:\>set Path= E:\jdk1.7.0_21;%Path%。

 E:\>set classpath=E:\  和  E:\>set classpath=E:\;  的区别

加分号的时候,首先在环境变量的目录下搜索class文件,如果没有找到,再在当前目录搜索class文件。

不加分号的时候,如果在环境变量的目录下没有搜索到class文件,不再在当前目录中搜索。

数据类型

基本数据类型包装类是按照面向对象的思想讲基本数据类型封装成了对象

基本数据类型  对象包装类 
 byte  Byte
 short  Short
 int  Integer
 long  Long
 boolean  Boolean
 float  Float
 double  Double
 char  Charactor

 

  

 

 

 

 

 

 

 

类型对象包装类都是final类

好处

  • 可以通过对象中的属性和行为操作基本数据类型。
  • 可以实现基本数据类型和字符串之间的转换。
    1. 基本数据类型转成字符串: Integer.toString(34);//将34整数变成"34";
    2. 字符串转成基本数据类型。
      • xxx a = Xxx.parseXxx(String);
      • int a = Integer.parseInt("123");
      • double b = Double.parseDouble("12.23");
      • boolean b = Boolean.parseBoolean("true");
  • 把基本数据类型对象包装类变成基本数据类型

Integer i = new Integer("123");

int num = i.intValue();

 整数进制转换

十进制转成其他进制

  • static String toBinaryString(int i) : 以二进制(基数 2)无符号整数形式返回一个整数参数的字符串表示形式。
  • toOctalString(int i) : 八进制
  • toHexString(int i ) ; 十六进制。

 其他进制转成十进制

  • parseInt(string,radix); Radix转换成的进制。使用第二个参数指定的基数,将字符串参数解析为有符号的整数。

int x = Integer.parseInt("110",10);
int x1 = Integer.parseInt("110",2);
System.out.println(x);//110
System.out.println(x1);//6

 负数的二进制

逻辑运算符

"&"  和  "&&"  的区别

  • 单& 时,左边无论真假,右边都进行运算;

  • 双& 时,如果左边为真,右边参与运算,如果左边为假,那么右边不参与运算。

  • “|” 和“||”的区别同理,双或时,左边为真,右边不参与运算。 

  • 异或( ^ ) 与或( | ) 的不同之处是:当左右都为true 时, 结果为false。

位运算符

package test;

/**
 * ^的运算方法是 相同为0,相反为1
 * |的运算方法是 有1则为1
 * &的运算方式是 有0则为0
 * ~的运算方法是 求反,负数的二进制表示就是该负数的绝对值的二进制数按位取反再加一
 * >>n的运算方式 右移n位,正填0,负填1,正数x/(2^n)
 * <<n的运算方式 左移n位,正填0,负填1,正数x*(2^n)
 * >>>n的运算方式  不带符号右移n位,填0,32位系统是该数前补足32个0,64位补足64个0
 */

public class TestOperation {
	
	public static void main(String[] args) {
		System.out.println(1^2);
		/*
		 * 1 001
		 * 2 010
		 * 3 011
		 */
		
		System.out.println(4^5);
		/*
		 * 4 100
		 * 5 101
		 * 1 001
		 */
		
		System.out.println(15^21);
		/*
		 * 15 01111
		 * 21 10101
		 * 26 11010
		 */
		
		System.out.println("-----");
		
		System.out.println(1|2);
		/*
		 * 1 001
		 * 2 010
		 * 3 011
		 */
		
		System.out.println(4|5);
		/*
		 * 4 100
		 * 5 101
		 * 5 101
		 */
		
		System.out.println(15|21);
		/*
		 * 15 01111
		 * 21 10101
		 * 31 11111
		 */
		
		System.out.println("-----");
		
		System.out.println(1&2);
		/*
		 * 1 001
		 * 2 010
		 * 0 000
		 */
		
		System.out.println(4&5);
		/*
		 * 4 100
		 * 5 101
		 * 4 100
		 */
		
		System.out.println(15&21);
		/*
		 * 15 01111
		 * 21 10101
		 * 5  00101
		 */
		
		System.out.println("-----");
		
		System.out.println(~5);
		
		/*
		 * 5 00000101
		 *-6 11111010
		 *   00000101+1
		 * 
		 */
		
		System.out.println(~21);
		
		/*
		 * 21 00010101
		 *-22 11101010
		 *    00010101+1
		 *  
		 */
		
		System.out.println(~-16);
		
		/*
		 *-16 11110000
		 * 15 00001111
		 */
		
		System.out.println("-----");
		
		System.out.println(15>>2);
		
		/*
		 * 15 01111
		 * 3  011
		 */
		
		System.out.println("-----");
		
		System.out.println(15<<2);
		
		/*
		 * 15 0001111
		 * 60 0111100
		 */

		System.out.println("-----");
		
		System.out.println(-5>>>2);
		
		/*
		 *  5 00000101
		 * -5 11111011
		 *    2^32右移2个0
		 */
		
		System.out.println(-5>>>30);
		
		/*
		 * -5 11111011
		 *    2^32右移30个0
		 *    00000011
		 */
	}
}

移位运算的总结

对于左移运算:

  • 每左移一个位,高阶位都被移出(并且丢弃),并用0填充右边。【这意味着当左移的运算数是int 类型时,每移动1位,它的第31位就要被移出并且丢弃;当左移的运算数是long 类型时,每移动1位它的第63位就要被移出并且丢弃】。
  • 左移都可以使原来的操作数翻倍,程序员们经常使用这个办法来进行快速的 2 的乘法。但是你要小心,如果你将1移进高阶位(31或63位),那么该值将变为负值

对于右移运算:

  • 每右移一次,就相当于将该值除以2并且舍弃了余数。你可以利用这个特点将一个整数进行快速的2的除法。当然,你一定要确保你不会将该数原有的任何一位移出。

在对byte 和short类型的值进行移位运算时 , Java将自动把这些类型扩大为 int 型,而且,移位后的值也是int 型;如果左移不超过31位,原来对应各位的值不会丢弃。但是,如果你对一个负的byte 或者short类型的值进行移位运算,它被扩大为int 型后,它的符号也被扩展,结果的高位就会被1填充。因此,为了得到正确的结果,你就要舍弃得到结果的高位。这样做的最简单办法是将移位运算的结果再转换成 byte 型 。

无符号右移(>>>) 与 右移(>>)的区别

  • 每一次右移(>>)运算符总是自动地用它的先前最高位的内容补它的最高位。这样做保留了原值的符号
  • 无符号移动(>>>)总是在高位(最左边)补0。

 

 

 

posted @ 2014-07-20 20:59  iadanac  阅读(276)  评论(0编辑  收藏  举报