首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

如何证明sleep释放锁,而wait释放锁?

代码解析 从上述代码可以看出,我们给 wait() 和 notify() 两个方法上了同一把锁(locker),但在调用完 wait() 方法之后 locker 锁就被释放了,所以程序才能正常执行 notify...() 的代码,因为是同一把锁,如果释放锁的话,是不会执行 notify() 的代码的,这一点也可以从打印的结果中证实(结果输出顺序),所以综合以上情况来说 wait() 方法是释放锁的。...notify() 方法并没有获取到 locker 锁,从上述执行结果中可以看出,而是执行完 sleep(1000) 方法之后才执行的 notify() 方法,因此可以证明调用 sleep() 方法并不会释放锁...static 中使用,源码如下: public final void wait() throws InterruptedException { wait(0); } 3.wait/notify 可以搭配...不行,因为搭配 synchronized 使用的话程序会报错,如下图所示: ?

2.6K20

漫画:如何证明sleep释放锁,而wait释放锁?

代码解析 从上述代码可以看出,我们给 wait() 和 notify() 两个方法上了同一把锁(locker),但在调用完 wait() 方法之后 locker 锁就被释放了,所以程序才能正常执行 notify...() 的代码,因为是同一把锁,如果释放锁的话,是不会执行 notify() 的代码的,这一点也可以从打印的结果中证实(结果输出顺序),所以综合以上情况来说 wait() 方法是释放锁的。...notify() 方法并没有获取到 locker 锁,从上述执行结果中可以看出,而是执行完 sleep(1000) 方法之后才执行的 notify() 方法,因此可以证明调用 sleep() 方法并不会释放锁...static 中使用,源码如下: public final void wait() throws InterruptedException { wait(0); } 3.wait/notify 可以搭配...不行,因为搭配 synchronized 使用的话程序会报错,如下图所示: 更深层次的原因是因为不加 synchronized 的话会造成 Lost Wake-Up Problem,唤醒丢失的问题,

1.1K30

【教程】truncate清空表数据,为什么数据库的空间还是和原来一样并没有释放|truncate table 空间没有释放|数据库释放表空间教程|

前言 我们经常会被问到delete和truncate的区别,然后我们经常回答delete是删除表数据,truncate是清空表, 但是你有没有想过,当你用truncate清空表数据的时候,为什么数据库的空间还是和原来一样并没有释放...一、为什么truncate不会立即释放表空间 那是因为当使用truncate命令清空表数据时,数据库并不会立即释放空间。相反,它会将空间标记为可重用,以便在以后插入新数据时可以使用。...这是因为truncate命令是一种快速清空表数据的方法,它不会逐行删除数据,而是直接删除整个表的数据。因此,数据库并不会像使用delete命令一样逐行删除数据并释放空间。...如果您想要立即释放空间,可以使用alter table命令来重建表,或使用vacuum命令来清理数据库中的未使用空间。

39400

delete、truncate、drop,千万别用错了。。

,InnoDB 不会释放磁盘空间; 5、对于delete from table_name where xxx 带条件的删除, 不管是InnoDB还是MyISAM都不会释放磁盘空间; 6、delete操作以后使用...optimize table table_name 会立刻释放磁盘空间。...示例:查看表占用硬盘空间大小的SQL语句如下:(用M做展示单位,数据库名:csjdemo,表名:demo2) select concat(round(sum(DATA_LENGTH/1024/1024)...2、truncate Truncate table TABLE_NAME 1、truncate:属于数据库DDL定义语言,走事务,原数据不放到 rollback segment 中,操作触发 trigger...执行后立即生效,无法找回 执行后立即生效,无法找回 执行后立即生效,无法找回 2、truncate table table_name 立刻释放磁盘空间 ,不管是 InnoDB和MyISAM 。

8810

delete、truncate、drop的区别有哪些,该如何选择

往期面试题汇总:001期~150期汇总 示例:查看表占用硬盘空间大小的SQL语句如下:(用M做展示单位,数据库名:csjdemo,表名:demo2) select concat(round(sum(DATA_LENGTH...往期面试题汇总:001期~150期汇总 2、truncate Truncate table TABLE_NAME 1、truncate:属于数据库DDL定义语言,走事务,原数据不放到 rollback...segment 中,操作触发 trigger。...执行后立即生效,无法找回 执行后立即生效,无法找回 执行后立即生效,无法找回 2、truncate table table_name 立刻释放磁盘空间 ,不管是 InnoDB和MyISAM 。...属于数据库DDL定义语言,同Truncate; 执行后立即生效,无法找回 执行后立即生效,无法找回 执行后立即生效,无法找回 2、drop table table_name 立刻释放磁盘空间 ,不管是

44230

面试官灵魂一问: MySQL 的 delete、truncate、drop 有什么区别?

optimize table table_name 会立刻释放磁盘空间。...示例:查看表占用硬盘空间大小的SQL语句如下:(用M做展示单位,数据库名:csjdemo,表名:demo2) select concat(round(sum(DATA_LENGTH/1024/1024)...2、truncate Truncate table TABLE_NAME 1、truncate:属于数据库DDL定义语言,走事务,原数据不放到 rollback segment 中,操作触发 trigger...执行后立即生效,无法找回 执行后立即生效,无法找回 执行后立即生效,无法找回 2、 truncate table table_name 立刻释放磁盘空间 ,不管是 InnoDB和MyISAM 。...:属于数据库DDL定义语言,同Truncate; 执行后立即生效,无法找回 执行后立即生效,无法找回 执行后立即生效,无法找回 2、 drop table table_name 立刻释放磁盘空间 ,不管是

1K20

delete、truncate、drop的区别有哪些,该如何选择

optimize table table_name 会立刻释放磁盘空间。...示例:查看表占用硬盘空间大小的SQL语句如下:(用M做展示单位,数据库名:csjdemo,表名:demo2) select concat(round(sum(DATA_LENGTH/1024/1024)...2、truncate Truncate table TABLE_NAME 1、truncate:属于数据库DDL定义语言,走事务,原数据不放到 rollback segment 中,操作触发 trigger...执行后立即生效,无法找回 执行后立即生效,无法找回 执行后立即生效,无法找回 2、truncate table table_name 立刻释放磁盘空间 ,不管是 InnoDB和MyISAM 。...属于数据库DDL定义语言,同Truncate; 执行后立即生效,无法找回 执行后立即生效,无法找回 执行后立即生效,无法找回 2、drop table table_name 立刻释放磁盘空间 ,不管是

1.2K00

delete、truncate、drop的区别有哪些,该如何选择

往期面试题汇总:001期~150期汇总 示例:查看表占用硬盘空间大小的SQL语句如下:(用M做展示单位,数据库名:csjdemo,表名:demo2) select concat(round(sum(DATA_LENGTH...往期面试题汇总:001期~150期汇总 2、truncate Truncate table TABLE_NAME 1、truncate:属于数据库DDL定义语言,走事务,原数据不放到 rollback...segment 中,操作触发 trigger。...执行后立即生效,无法找回 执行后立即生效,无法找回 执行后立即生效,无法找回 2、truncate table table_name 立刻释放磁盘空间 ,不管是 InnoDB和MyISAM 。...DDL定义语言,同Truncate; 执行后立即生效,无法找回 执行后立即生效,无法找回 执行后立即生效,无法找回 2、drop table table_name 立刻释放磁盘空间 ,不管是 InnoDB

44110

delete、truncate、drop的区别有哪些,该如何选择

示例:查看表占用硬盘空间大小的SQL语句如下:(用M做展示单位,数据库名:csjdemo,表名:demo2) select concat(round(sum(DATA_LENGTH/1024/1024)...往期面试题汇总:001期~150期汇总 Truncate table TABLE_NAME 1、truncate:属于数据库DDL定义语言,走事务,原数据不放到 rollback segment 中...,操作触发 trigger。...执行后立即生效,无法找回 执行后立即生效,无法找回 执行后立即生效,无法找回 2、truncate table table_name 立刻释放磁盘空间 ,不管是 InnoDB和MyISAM 。...属于数据库DDL定义语言,同Truncate; 执行后立即生效,无法找回 执行后立即生效,无法找回 执行后立即生效,无法找回 2、drop table table_name 立刻释放磁盘空间 ,不管是

41520

教同事小姐姐删除MySQL数据的几种姿势

optimize table table_name 会立刻释放磁盘空间。...示例:查看表占用硬盘空间大小的SQL语句如下:(用M做展示单位,数据库名:csjdemo,表名:demo2) select concat(round(sum(DATA_LENGTH/1024/1024)...2、truncate Truncate table TABLE_NAME 1、truncate:属于数据库DDL定义语言,走事务,原数据不放到 rollback segment 中,操作触发 trigger...执行后立即生效,无法找回 执行后立即生效,无法找回 执行后立即生效,无法找回 2、truncate table table_name 立刻释放磁盘空间 ,不管是 InnoDB和MyISAM 。...:属于数据库DDL定义语言,同Truncate; 执行后立即生效,无法找回 执行后立即生效,无法找回 执行后立即生效,无法找回 2、drop table table_name 立刻释放磁盘空间 ,不管是

47120
领券