说说synchronized关键字和volatile关键字的区别

说说synchronized关键字和volatile关键字的区别

synchronized关键字和volatile关键字是两个互补的存在,而不是对立的存在

  • volatile关键字是线程同步的轻量级实现,所以volatile性能肯定比synchronized关键字要好,但volatile关键字只能用于变量,而synchronized可以修饰方法和代码块
  • volatile关键字能保证数据的可见性,但不能保证原子性。synchronized两者都能保证
  • volatile关键字主要用于解决变量在多个线程之间的可见性,而synchronized解决的是多个线程之间访问资源的同步性

查看mysql提供的所有存储引擎

mysql>show engines;

mysql当前默认的存储引擎是InnoDB,并且在5.7版本中只有InooDB是事务性存储引擎,也就是说只有InooDB支持事务。

查看mysql当前默认的存储引擎

show variables like '%storage_engine%';

MyISAM和InnoDB区别

MyISAM是MySQL的默认数据库引擎(5.5版之前)。虽然性能极佳,⽽且提供了⼤量的特性, 包括全⽂索引、压缩、空间函数等,但MyISAM不⽀持事务和⾏级锁,⽽且最⼤的缺陷就是崩溃 后⽆法安全恢复。不过,5.5版本之后,MySQL引⼊了InnoDB(事务性数据库引擎),MySQL 5.5版本后默认的存储引擎为InnoDB。 ⼤多数时候我们使⽤的都是 InnoDB 存储引擎,但是在某些情况下使⽤ MyISAM 也是合适的⽐如 读密集的情况下。(如果你不介意 MyISAM 崩溃恢复问题的话)。

两者的对⽐

  1. 是否⽀持⾏级锁 : MyISAM 只有表级锁(table-level locking),⽽InnoDB ⽀持⾏级锁(rowlevel locking)和表级锁,默认为⾏级锁。

  2. 是否⽀持事务和崩溃后的安全恢复: MyISAM 强调的是性能,每次查询具有原⼦性,其执⾏ 速度⽐InnoDB类型更快,但是不提供事务⽀持。但是InnoDB 提供事务⽀持事务,外部键等 ⾼级数据库功能。 具有事务(commit)、回滚(rollback)和崩溃修复能⼒(crash recovery capabilities)的事务安全(transaction-safe (ACID compliant))型表。

  3. 是否⽀持外键: MyISAM不⽀持,⽽InnoDB⽀持。

  4. 是否⽀持MVCC :仅 InnoDB ⽀持。应对⾼并发事务, MVCC⽐单纯的加锁更⾼效;MVCC只 在 READ COMMITTED 和 REPEATABLE READ 两个隔离级别下⼯作;MVCC可以使⽤ 乐 观(optimistic)锁 和 悲观(pessimistic)锁来实现;各数据库中MVCC实现并不统⼀。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值