日常杂项

  • Oracle按天(自定义)分组,查询每天前100条

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;

  • 如何保证线程的执行顺序

  1. 在主线程里面每开启一个新的子线程(start方法),紧接着再子线程.join()方法,意思是让主线程下的这个子线程执行完了以后再执行下一个子线程。
  2. ExecutorService executorService = Executors.newSingleThreadExecutor();
    executorService .submit(线程);
    这样即可按照加入的顺序执行相关线程。
  • volatile 和 synchronized 的区别

  1. volatile 本质是在告诉 JVM 当前变量在寄存器(工作内存)中的值是不确定的,需要从主存中读取。
  2. synchronized 则是锁定当前变量,只有当前线程可以访问该变量,其他线程被阻塞住。
  3. volatile 仅能使用在变量级别。synchronized 则可以使用在变量、方法、和类级别的。
  4. volatile 仅能实现变量的修改可见性,不能保证原子性。而synchronized 则可以保证变量的修改可见性和原子性。
  5. volatile 不会造成线程的阻塞。synchronized 可能会造成线程的阻塞。
  6. volatile 标记的变量不会被编译器优化。synchronized标记的变量可以被编译器优化。
  • 多线程

继承Thread类和实现Ruunable接口
Thread类的join方法强制开始执行此线程
在start方法前可以设置守护线程true

  • 设计模式

spring的beanFactory工厂模式
单例模式

  • 锁的膨胀过程

  • 偏向所锁,轻量级锁都是乐观锁,重量级锁是悲观锁。
  1. 一个对象刚开始实例化的时候,没有任何线程来访问它的时候。它是可偏向的,意味着,它现在认为只可能有一个线程来访问它,所以当第一个线程来访问它的时候,它会偏向这个线程,此时,对象持有偏向锁。偏向第一个线程,这个线程在修改对象头成为偏向锁的时候使用CAS操作,并将对象头中的ThreadID改成自己的ID,之后再次访问这个对象时,只需要对比ID,不需要再使用CAS在进行操作。
  2. 一旦有第二个线程访问这个对象,因为偏向锁不会主动释放,所以第二个线程可以看到对象时偏向状态,这时表明在这个对象上已经存在竞争了,检查原来持有该对象锁的线程是否依然存活,如果挂了,则可以将对象变为无锁状态,然后重新偏向新的线程,如果原来的线程依然存活,则马上执行那个线程的操作栈,检查该对象的使用情况,如果仍然需要持有偏向锁,则偏向锁升级为轻量级锁,( 偏向锁就是这个时候升级为轻量级锁的)。如果不存在使用了,则可以将对象回复成无锁状态,然后重新偏向。
  3. 轻量级锁认为竞争存在,但是竞争的程度很轻,一般两个线程对于同一个锁的操作都会错开,或者说稍微等待一下(自旋),另一个线程就会释放锁。 但是当自旋超过一定的次数,或者一个线程在持有锁,一个在自旋,又有第三个来访时,轻量级锁膨胀为重量级锁,重量级锁使除了拥有锁的线程以外的线程都阻塞,防止CPU空转。
  1. 锁对象的对象头64bit 前56位是这个锁对象的hash 记录着这个对象的字节码对象的地址
    接下来1位unused,后四位是分代年龄,后一位表示偏向状态,最后两位是锁的无锁、偏向锁、轻量锁、重量锁、GC标记的状态。
    001无锁 101偏向锁 000 轻量锁 010 重量锁 001无锁–GC标记
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值