@0610知识点整理TOC
标题 java怎么保证多线程的运行安全
1、原子性(线程切换带来的原子性问题);用原子类,用synchronized和lock
2、可见性(缓存带来的可见性的问题);用synchronized和lock,还有volatile
3、有序性(编译优化带来的可见性的问题);happens-before
happens-before规则:
1、程序顺序规则:先写的先运行;
2、锁定规则:unlock在后面的lock运行;
3、volatile:volatile相比于后面的先运行;
4、启动(thread 的start先运行)、终止(所有都先发于终止)、中断(interrupt先运行):
MySQL运行慢:
1、计算资源不足;
2、系统未进行优化,存在进程之间的资源抢占;
3、MySQL配置不科学;
4、sql语句不规范;
单例模式:
1、什么是单例模式:单例对象的类只能允许一个实例存在
2、实现:(1)类中的方法定义为私有;
(2)提供一个静态方法;
3、应用场景:(1)windows桌面上,我们打开了一个回收站,再打开是,则还是原来的那个窗口,windows并不会打开两个窗口;(2)网站的计数器
4、单例模式的优缺点:
优点:(1)只有一个对象,节省内存空间;(2)避免频繁的创建销毁对象,可以提高性能
缺点:(1)不适用于变化频繁的对象;(2)节省资源将数据库连接池对象设计为的单例类,可能会导致共享连接池对象的程序过多而出现连接池溢出
5、单例模式的实现:
(1)饿汉式:
优点:写法比较简单,就是在类装载的时候就完成实例化。避免了线程同步问题。
缺点:在类装载的时候就完成实例化,没有达到Lazy Loading的效果。如果从始至终从未使用过这个实例,则会造成内存的浪费。
public static Singleton1{
//指向自己的私有实例方法
private static Singleton1 singleton1 = new Singleton1();
//构造私有方法:
private Singleton1();
// 以自己实例为返回值的静态的公有方法,静态工厂方法
public static Singleton1 getSingleton1(){
return singleton1;
}
}
(2)懒汉式;单例实例被延迟加载,只能在单线程下使用
(3)双重加锁机制;
(4)静态初始化:
jvm分为哪些区域
pc计数器(执行指令),堆(存储对象本身的以及数组),方法区(类的属性),本地方法栈(为本地方法),java虚拟机栈(为执行Java方法服务)
乐观锁和悲观锁:
1、定义:
2、使用场景:乐观:读大于写的业务场景;悲观:写大于读的情况
3、实现:乐观:版本号和CAS(内存值,旧值,新值)内存值与期望值一致时就会更新数据,反之不操作
悲观:数据库:加锁(表锁、行锁和页锁);‘java:synchronizeda关键字
一、mysql复制表的两种方式。
第一、只复制表结构到新表
create table 新表 select * from 旧表 where 1=2
或者 create table 新表 like 旧表
第二、复制表结构及数据到新表
create table 新表 select * from 旧表