select *
from (select t.*, rank() over(partition by
to_char(t.create_date_日期字段,‘yyyy-mm-dd’)
order by t.rowid) rk
from sys_user_表名 t
where t.create_date_日期字段 between
to_date(‘2020-11-01’, ‘yyyy-mm-dd’) and
to_date(‘2020-12-06’, ‘yyyy-mm-dd’)
)
where rk <= 100;
- 在主线程里面每开启一个新的子线程(start方法),紧接着再子线程.join()方法,意思是让主线程下的这个子线程执行完了以后再执行下一个子线程。
- ExecutorService executorService = Executors.newSingleThreadExecutor();
executorService .submit(线程);
这样即可按照加入的顺序执行相关线程。
- volatile 本质是在告诉 JVM 当前变量在寄存器(工作内存)中的值是不确定的,需要从主存中读取。
- synchronized 则是锁定当前变量,只有当前线程可以访问该变量,其他线程被阻塞住。
- volatile 仅能使用在变量级别。synchronized 则可以使用在变量、方法、和类级别的。
- volatile 仅能实现变量的修改可见性,不能保证原子性。而synchronized 则可以保证变量的修改可见性和原子性。
- volatile 不会造成线程的阻塞。synchronized 可能会造成线程的阻塞。
- volatile 标记的变量不会被编译器优化。synchronized标记的变量可以被编译器优化。
继承Thread类和实现Ruunable接口
Thread类的join方法强制开始执行此线程
在start方法前可以设置守护线程true
spring的beanFactory工厂模式
单例模式
- 一个对象刚开始实例化的时候,没有任何线程来访问它的时候。它是可偏向的,意味着,它现在认为只可能有一个线程来访问它,所以当第一个线程来访问它的时候,它会偏向这个线程,此时,对象持有偏向锁。偏向第一个线程,这个线程在修改对象头成为偏向锁的时候使用CAS操作,并将对象头中的ThreadID改成自己的ID,之后再次访问这个对象时,只需要对比ID,不需要再使用CAS在进行操作。
- 一旦有第二个线程访问这个对象,因为偏向锁不会主动释放,所以第二个线程可以看到对象时偏向状态,这时表明在这个对象上已经存在竞争了,检查原来持有该对象锁的线程是否依然存活,如果挂了,则可以将对象变为无锁状态,然后重新偏向新的线程,如果原来的线程依然存活,则马上执行那个线程的操作栈,检查该对象的使用情况,如果仍然需要持有偏向锁,则偏向锁升级为轻量级锁,( 偏向锁就是这个时候升级为轻量级锁的)。如果不存在使用了,则可以将对象回复成无锁状态,然后重新偏向。
- 轻量级锁认为竞争存在,但是竞争的程度很轻,一般两个线程对于同一个锁的操作都会错开,或者说稍微等待一下(自旋),另一个线程就会释放锁。 但是当自旋超过一定的次数,或者一个线程在持有锁,一个在自旋,又有第三个来访时,轻量级锁膨胀为重量级锁,重量级锁使除了拥有锁的线程以外的线程都阻塞,防止CPU空转。
- 锁对象的对象头64bit 前56位是这个锁对象的hash 记录着这个对象的字节码对象的地址
接下来1位unused,后四位是分代年龄,后一位表示偏向状态,最后两位是锁的无锁、偏向锁、轻量锁、重量锁、GC标记的状态。
001无锁 101偏向锁 000 轻量锁 010 重量锁 001无锁–GC标记