比如 销售量 不能超销售计划数量执行
每次做销售订单是都需要去判断 计划数量是否执行完成 如果执行完成就不能在继续做销售订单
现在我处理是这样的
boolean checkAmount(){
}
synchronized checkAndSaveOrders(Order order){
if(checkAmount){
save(order);
}
}
在多线程环境下 不知道是否合理
synchronized 会带来性能损耗
不知道有无其他代替方法?
好的设计思路
一般情况下很少碰到并发冲突(因为互斥的并发量不大,看具体业务情况)。此时简单的synchornized应该对性能影响不大。
如果确实需要,则可以考虑在最小的范围内同步(加锁),而不是在全局范围内加锁。
但我不清楚你的具体业务,哪里需要同步。
要注意,即使是上述方法可用,但在多JVM如负载均衡或集群情况下,也会失效,因为同步的范围仅在一个JVM中有效。
此时可以考虑以数据库或其他方式为中介,建立一个跨JVM的同步机制。