阻塞和死锁是两个不同的概念。
举个例子,现在有线程1和线程2,线程1占用了资源A,线程2占用了资源B。此时线程2需要使用资源A才能继续,但是资源A被线程1所占用,那么线程2只能等待资源A被线程1释放掉,这种情况称为线程2被阻塞。
但是,如果此时线程1也许要资源B才能继续,那么两个线程都会等待对方释放资源,这种情况就是死锁。
简单地讲,阻塞一般是没有循环调用的,而死锁是有循环调用情况的。
以下一些内容供您参考:
了解和解决 SQL Server 7.0 或 2000 阻塞问题
http://support.microsoft.com/?id=224453
阻塞是没有办法避免的,只要有并发的任务执行,就有可能发生这个现象。
死锁是我们应该重点避免的,主要的方法就是在编写程序的时候尽量考虑使用各种方法避免循环调用,同时设置一个最长等待时间。