Java读书笔记1
Java逍遥游记读书笔记
前言
必须先来一句,这是入门级别,高手勿喷~
写Android的时候总有一些语句不是很理解,其实大部分是Java的内容,所以想系统的学下Java。
这本书——《Java逍遥游记》是在图书馆偶然看到的,被横放在书架上,看来是被人翻过直接丢那里了,索性拿来看一看。
很基础的一本书,废话很多,比如孙悟空想学编程什么什么的,但可以理解作者的一片苦心。既然如此水,那就把它借回来想快速扫一下以增加成就感,用一种查漏补缺的态度,看到哪里不会就记下来,最终目标就是这本书就作废了,对我有价值的东西都在笔记上,所以就有了这几篇笔记。
Anyway,一千个人眼中有一千个哈姆雷特,我记下的东西不一定适合所有人,这里面既有Java的内容,也有些是我在学C++的时候的一些遗漏(语言都是相通的~),所以抱着交流学习的态度的同时更多的是对自己知识的归纳整理。若这些东西对你有用,那便是极好的。
另外大神读书都是1,2天一本,我做不到,但还是力求能快速看完,截止到现在2013-09-22 20:20:14,已看完1-9章,剩下的10-22章,暂定一个星期,在国庆节到来之前结束这本书的阅读,同时做好笔记。
HelloWorld
一、前提:已安装好Jdk。
二、配置环境变量:
新建环境变量JAVA_HOME:F:\JDK (这是我的路径)
编辑path变量:添加%JAVA_HOME%\bin;
编辑CLASSPATH变量:C:\Users\Administrator\Desktop;
有必要解释下ClassPath变量,你通过javac编译出来的.class文件必须放置在ClassPath中任意路径中,才能运行成功,比如我把Hello.class放在桌面,那么为了运行成功,我就在ClassPath中添加桌面的路径C:\Users\Administrator\Desktop;否则会出现
错误:找不到或无法加载主类
运行cmd
定位到Hello.java所在位置
键入javac Hello.java
键入 java Hello (注意没有.class)
public class Hello
{
public static void main(String[] args)
{
System.out.println("Hello, world!");
}
}
Hello.java
public class Hello
{
public static void main(String[] args)
{
System.out.println("Hello, world!");
}
}
程序入口main函数
必须是public,static,void,String数组参数,缺一不可。
public static void main(String[] args){}
Java的编译与运行
Java源文件结构
每个Java源文件可以有多个类的定义,但最多只能有一个类是public的,而且该源文件必须以public类的名字命名。
(注:Java中类的定义后面分号不是必须的)
public class Test{} class Sample1{} class Sample2{}
public class Test{} class Sample1{} class Sample2{}
包的引入
假如com.java.school里有一些类,同时还有一个文件夹classes,那么
import com.java.school.*;
只会引入school根目录下的所有类(*表示所有),而不会引入classes目录下的类。若还想继续引用classes下的类,则应当这样写。
import com.java.school.*;
import com.java.school.classes.*;
编程规范
- 类:所有单词首字母大写。如Monkey、SmartMonkey
- 方法和变量:首字母小写,其余单词首字母大写。如add、listAll
- 包:全部小写。如com.java.school.classes
- 常量:全部大写,若多个单词则加下划线隔开。如final String COLOR_OF_MONKET = “red”;
实例变量和静态变量(类变量)
- 无论你创建了多少实例,类的静态变量在内存中只有一个,被类的所有实例共享。
- 静态变量可以通过实例名访问,也可以通过类名被访问。
- 每创建一个实例,系统就会为实例变量分配一次内存。
- 实例变量只能通过实例名访问。
具体看下例子就可以懂了。
public class Person
{
public int id = 0; //Java支持在声明时初始化
public static int sum = 0; //Java支持在声明时初始化
public Person()
{
id++;
sum++;
}
public static void main(String[] args)
{
Person p1 = new Person();
Person p2 = new Person();
System.out.println(p1.id); //输出1
System.out.println(p2.id); //输出1
System.out.println(Person.sum); //输出2 静态变量可以通过类名访问
}
}
Person.java
Person.java
public class Person
{
public int id = 0; //Java支持在声明时初始化 public static int sum = 0; //Java支持在声明时初始化 public Person()
{
id++; sum++;
} public static void main(String[] args)
{
Person p1 = new Person(); Person p2 = new Person(); System.out.println(p1.id); //输出1 System.out.println(p2.id); //输出1 System.out.println(Person.sum); //输出2 静态变量可以通过类名访问
}
} Person.java
操作符& |
&&和&都是与操作,那么有什么区别呢?
public class Test
{
public static void main(String[] args)
{
int a = -1, b = -1;
if ((a = 0) == 1 && (b = 1) == 1)
{}
System.out.println(a); //输出0赋值成功
System.out.println(b); //输出-1赋值失败
a = -1; b = -1;
if ((a = 0) == 1 & (b = 1) == 1)
{}
System.out.println(a); //输出0赋值成功
System.out.println(b); //输出1赋值成功
}
}
Test.java
public class Test
{
public static void main(String[] args)
{
int a = -1, b = -1;
if ((a = 0) == 1 && (b = 1) == 1)
{}
System.out.println(a); //输出0赋值成功
System.out.println(b); //输出-1赋值失败 a = -1; b = -1;
if ((a = 0) == 1 & (b = 1) == 1)
{}
System.out.println(a); //输出0赋值成功
System.out.println(b); //输出1赋值成功
}
}
可以看到,当第一条件判断为false的时候,&&是不会继续执行、判断第二个条件的,但&会。|也同理。
==操作符与equals()方法
这个已经被坑过很多很多次了。String的比较全部用equals()不能用==就一定不会错……
若是基本类型,如int,double,string等等,用==就可以比较相等。
若是引用类型,如String,Integer或自己写的类等等,用==比较的是是否同一个对象(内存地址是否相同),但我们一般要比价的是内容,所以应该有equals()方法。
public class Test
{
public static void main(String[] args)
{
String s1 = "123", s2 = "123";
String s3 = new String("123"), s4 = new String("123");
String s5 = s3;
System.out.println(s1 == s2); //true
System.out.println(s3 == s4); //false
System.out.println(s3 == s5); //true
System.out.println(s3.equals(s4)); //true
Integer i1 = new Integer(1), i2 = new Integer(1);
System.out.println(i1 == i2); //false
System.out.println(i1.equals(i2)); //true
}
}
Test.java
public class Test
{
public static void main(String[] args)
{
String s1 = "123", s2 = "123"; String s3 = new String("123"), s4 = new String("123"); String s5 = s3; System.out.println(s1 == s2); //true System.out.println(s3 == s4); //false System.out.println(s3 == s5); //true System.out.println(s3.equals(s4)); //true Integer i1 = new Integer(1), i2 = new Integer(1); System.out.println(i1 == i2); //false System.out.println(i1.equals(i2)); //true
}
}
必要时可以覆盖equals()方法
public class Student
{
public String name;
public int age;
public boolean equals(Object o)
{
if (this == o)
return true;
if (!(o instanceof Student)) //判断是否Student的实例
return false;
final Student student = (Student)o; //强制类型转换
return this.name.equals(student.name);
}
public Student(String name, int age)
{
this.name = name;
this.age = age;
}
public static void main(String[] args)
{
Student m1 = new Student("Norcy", 22), m2 = new Student("Fiona", 21), m3 = new Student("Norcy", 23);
System.out.println(m1.equals(m2)); //false
System.out.println(m1.equals(m3)); //true
}
}
Student.java
public class Student
{
public String name; public int age; public boolean equals(Object o)
{
if (this == o)
return true;
if (!(o instanceof Student)) //判断是否Student的实例
return false; final Student student = (Student)o; //强制类型转换 return this.name.equals(student.name);
} public Student(String name, int age)
{
this.name = name; this.age = age;
} public static void main(String[] args)
{
Student m1 = new Student("Norcy", 22), m2 = new Student("Fiona", 21), m3 = new Student("Norcy", 23); System.out.println(m1.equals(m2)); //false System.out.println(m1.equals(m3)); //true
} }
instanceof操作符
判断一个对象是否为一个类的实例。
假如s1是Student类的实例,那么对于表达式“s instanceof XXX”,当XXX为以下值的时候,表达式的值为true.
- Student
- Student的直接父类或间接父类(即祖先)
- Student类实现的接口的名字(接口是什么,以后再学)
4种访问控制级别
public 对外公开
protected 向子类和同一个包中的所有类公开
默认 向同一个包中的所有类公开
private 只有类本身可以访问,不对外公开
访问级别:public > protected > default > private
若一个子类与父类在不同包,则这种情况属于不同包,不属于子类。
访问级别 |
同类 |
同包 |
子类 |
不同包 |
public |
√ |
√ |
√ |
√ |
protected |
√ |
√ |
√ |
— |
默认 |
√ |
√ |
— |
— |
private |
√ |
— |
— |
— |
Java读书笔记1的更多相关文章
- think in java 读书笔记 3 —— 数据报
目录 think in java 读书笔记 1 ——移位 think in java 读书笔记 2 —— 套接字 think in java 读书笔记 3 —— 数据报 概要 1. 数据报基本知识 2 ...
- think in java 读书笔记 2 —— 套接字
目录 think in java 读书笔记 1 ——移位 think in java 读书笔记 2 —— 套接字 think in java 读书笔记 3 —— 数据报 概要 1. 套接字基本知识 2 ...
- think in java 读书笔记 1 ——移位
目录 think in java 读书笔记 1 ——移位 think in java 读书笔记 2 —— 套接字 think in java 读书笔记 3 —— 数据报 在Think in Java中 ...
- Thinking In Java读书笔记--对象导论
Thinking In Java读书笔记--对象导论[对象]服务提供者==>将对象看做一个服务提供者[程序员分类][类创造者]/[客户端程序员] [访问控制存在的原因?][1]客户端程序员无法触 ...
- head first java读书笔记
head first java读书笔记 1. 基本信息 页数:689 阅读起止日期:20170104-20170215 2. 标签 Java入门 3. 价值 8分 4. 主题 使用面向对象的思路介绍J ...
- java读书笔记二
这是我的一些读书笔记: 我研究了一下面向对象: 面向对象符合人类看待事物的一般规律,对象的方法的实现细节是包装的,只有对象方法的实现者了解细节 我觉得面向过程是由过程.步骤.函数组成,过程是核心,面向 ...
- Effective Java读书笔记完结啦
Effective Java是一本经典的书, 很实用的Java进阶读物, 提供了各个方面的best practices. 最近终于做完了Effective Java的读书笔记, 发布出来与大家共享. ...
- Effective java读书笔记
2015年进步很小,看的书也不是很多,感觉自己都要废了,2016是沉淀的一年,在这一年中要不断学习.看书,努力提升自己 计在16年要看12本书,主要涉及java基础.Spring研究.java并发.J ...
- 【java读书笔记】——java开篇宏观把控 + HelloWorld
学完java有一段时间了,一直没有做对应的总结,总认为有一种缺憾.从这篇博客開始,将自己平时的学习笔记进行总结归纳,分享给大家. 这篇博客主要简单的介绍一下java的基础知识,基本的目的是扫盲.原来仅 ...
随机推荐
- HDOJ 5017 Ellipsoid
第一次尝试模拟退火..... Ellipsoid Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java ...
- Android学习----异常(2):Please ensure that adb is correctly located at ' ... '
打开任务管理器,在后台进程中找到 kadb,结束这个进程,重新启动eclipse.
- 两种计算和输出n内5要么9除尽互惠
#include<stdio.h> int main() { int i=0,n=0; float fSum=0; scanf("%d", &n); for ( ...
- linux_redhat_线程后台运行方法
建议看完1:后直接看2 screen 方式熟练些可靠. 次方法适用于redhat系统,unbunt* 系统用screen 命令 产看系统版本 cat /proc/version 首先项目制作的sh文件 ...
- Hadoop2.2.0--Hadoop Federation、Automatic HA、Yarn完全分布式集群结构
Hadoop有很多的上场时间,与系统上线.手头的事情略少.So,抓紧时间去通过一遍Hadoop2在下面Hadoop联盟(Federation).Hadoop2可用性(HA)及Yarn的全然分布式配置. ...
- cocos2d-x plist在拍照
if(!CCSpriteFrameCache::sharedSpriteFrameCache()->spriteFrameByName("scrollicon_bg.png" ...
- 给Notepad++ 6.7 加右键菜单带图标
使用的是Notepad++ 6.7,下载 NppShell64.dll 和 NppShell.dll方法:将BAT文件和下载的NppShell64.dll 和 NppShell.dll放置Notepa ...
- Web API-属性路由
路由(Routing)就是Web API如何将一个URI匹配到一个action的过程.Web API 2 支持一个新的路由方式-属性路由(attribute routing).顾名思义,属性路由使用标 ...
- 玩转Web之servlet(四)---B/S是怎样使用http协议完毕通信过程的
在上一篇文章中,我简单的说了一下B/S架构的流程图,关于浏览器和server之间的通信过程知识含糊的说了一下,在这篇文章中我再总结一下B/S架构里是怎样利用http协议去完毕通信的. (一)通讯过程 ...
- Chrome控制台 JS调试
Chrome控制台 JS调试的一些小技巧 $ $_命令返回最近一次表达式执行的结果,功能跟按向上的方向键再回车是一样的,但它可以做为一个变量使用在你接下来的表达式中. $0~$4则代表了最近5个你选择 ...