黑马程序员——第六天(包)
2015-07-18 09:37
696 查看
------<a href="http://www.itheima.com" target="blank">Java培训、Android培训、iOS培训、.Net培训</a>、期待与您交流! -------
一、包
作用:对类文件进行分类管理。
给类提供多层命名空间。
写在程序文件的第一行。
类名的全称是 包名.类名
包也是一种封装形式。
包与包之间进行访问:被访问的包中的类以及类中的成员,需要public修饰。
不同包中的子类还可以直接访问父类中被protected修饰的成员。
使用import关键字导入包。
二、多线程
进程:正在执行的一个程序。
线程:进程执行的控制单元。
多线程的目的:让多段代码同时运行。
创建线程的方式:1,继承Thread类--定义类继承Thread;复习Thread类的run方法;调用线程的start()方法;
覆盖run方法的原因:Thread类用于描述线程。该类定义了一个功能,用于存储线程要运行的代码。该存储功能就是run方法。
2,实现Runable接口
定义类实现Runable接口。
覆盖Runable中的run()方法。
通过Thread类建立线程对象。
将Runable接口的子类对象作为实现参数传递给Thread类的构造函数。
调用Thread类的start()方法启动线程并调用Runable子类的run()方法。
实现方式的好处:避免了单继承的局限性。
多线程运行的安全问题
问题的原因:当多条语句在操作同一个线程的共享数据时,一个线程对多条语句只执行了一部分,还没执行完,
另一个线程参与进来,导致共享数据的错误。
解决办法:对多条操作共享数据的语句,只能让一个线程都执行完。在执行过程中,其它线程不可以参与执行。
同步代码块解决线程安全问题:
synchtronized(对象)
{
}
同步函数用的锁,synchtronized函数都有一个所属对象引用。就是this。
所以同步函数所用的锁是this。
/*
单例设计模式中的同步代码块
*/
//饿汉式
/*
class Single
{
public static final Single s= new Single;
private Single() {}
public static Single getInstance()
{
retrun s;
}
}
*/
//懒汉式
class Single
{
public static Single s=null;
private Single(){}
public static Single getInstance()
{
if(s==null)//用双重判断减少了锁的判断次数
{
synchronized (Single.class)
if(s==null)
s= new Single();
return s;
}
}
}
一、包
作用:对类文件进行分类管理。
给类提供多层命名空间。
写在程序文件的第一行。
类名的全称是 包名.类名
包也是一种封装形式。
包与包之间进行访问:被访问的包中的类以及类中的成员,需要public修饰。
不同包中的子类还可以直接访问父类中被protected修饰的成员。
使用import关键字导入包。
二、多线程
进程:正在执行的一个程序。
线程:进程执行的控制单元。
多线程的目的:让多段代码同时运行。
创建线程的方式:1,继承Thread类--定义类继承Thread;复习Thread类的run方法;调用线程的start()方法;
覆盖run方法的原因:Thread类用于描述线程。该类定义了一个功能,用于存储线程要运行的代码。该存储功能就是run方法。
2,实现Runable接口
定义类实现Runable接口。
覆盖Runable中的run()方法。
通过Thread类建立线程对象。
将Runable接口的子类对象作为实现参数传递给Thread类的构造函数。
调用Thread类的start()方法启动线程并调用Runable子类的run()方法。
实现方式的好处:避免了单继承的局限性。
多线程运行的安全问题
问题的原因:当多条语句在操作同一个线程的共享数据时,一个线程对多条语句只执行了一部分,还没执行完,
另一个线程参与进来,导致共享数据的错误。
解决办法:对多条操作共享数据的语句,只能让一个线程都执行完。在执行过程中,其它线程不可以参与执行。
同步代码块解决线程安全问题:
synchtronized(对象)
{
}
同步函数用的锁,synchtronized函数都有一个所属对象引用。就是this。
所以同步函数所用的锁是this。
/*
单例设计模式中的同步代码块
*/
//饿汉式
/*
class Single
{
public static final Single s= new Single;
private Single() {}
public static Single getInstance()
{
retrun s;
}
}
*/
//懒汉式
class Single
{
public static Single s=null;
private Single(){}
public static Single getInstance()
{
if(s==null)//用双重判断减少了锁的判断次数
{
synchronized (Single.class)
if(s==null)
s= new Single();
return s;
}
}
}
相关文章推荐
- 黑马程序员——Java 反射 (第十二篇)
- 【从零单排之微软面试100题系列】11之二叉树中结点的最大距离
- 黑马程序员——基础学习感悟总结...
- 【LeetCode-面试算法经典-Java实现】【008-String to Integer (atoi) (字符串转成整数)】
- 【LeetCode-面试算法经典-Java实现】【007-Reverse Integer(翻转整数)】
- 【LeetCode-面试算法经典-Java实现】【006-ZigZag Conversion(Z字型转换)】
- 黑马程序员----java集合的分类与示例
- 说说面试的那点事
- 黑马程序员——泛型(Generic)的理解和使用
- 黑马程序员----java中的多态
- 从fork面试题开始的思考
- 软件类笔试题整理
- 面试题整理-01
- 2015071702 - 职场如战场
- 黑马程序员--java单列设计模式
- 黑马程序员_初识ios来源发展使用
- 黑马程序员----反射
- 黑马程序员----Java阶段性总结
- 黑马程序员----正则表达式,OMG
- 黑马程序员----浅谈RandomAccessFile格式化数据问题和多个对象序列化存取的两个方法