优势:
速度:应用并发系统可以同时处理多个请求,等待的时间就会变短,响应就会更快,另一个方面,复杂的操作可以分为多个进程同时操作加快了处理速度;
设计:假设一个应用程序需要从本地读取和处理两个文件,如果是都单线程的情况,我们就需要记录每个文件的读取和处理状态,如果使用并发处理,我们就可以启动两个线程,每个线程独立的处理一个文件的读取和操作。
资源利用:线程会在处理的时候被阻塞,其他线程可以在这段时间去进行其他操作;
风险:
安全性:之前的计数的例子。容易出现错误。
活跃性:如果在并发情况下进行加锁的操作来保证结果的准确性,如果加锁或者解锁不当就会引发死锁。
性能:CPU频繁切换,而且需要同步执行就会导致许多的优化被抑制,且并发的情况下会消耗过多的内存。