A forma de introducción, PLinQ,
ofrece la capacidad de realizar consultas LinQ
To Objects, de forma paralela, ósea
utilizando todos los cores
(núcleos) de el microprocesador. En un primer vistazo, podemos pensar que esto
es magia, pero como veremos a continuación, no es algo que sea 100%
recomendable en todos los casos, y puede llegar a tener una serie de
consideraciones y fallos, que o bien no conocemos o no estamos acostumbrados en
la programación síncrona.
Una de las ideas que solemos tener en nuestra cabeza acerca
de la programación en paralelo, es que si poseemos una máquina con 4 cores o microprocesadores, un
trabajo que tarda en hacerse 20 segundos, debería de tardar 20/4, solo 5
segundos. Esto no es cierto, hay algunos casos en que la ejecución sobre un
único núcleo es más rápida que sobre n.
La diferencia radica, en que para poder hacer una ejecución en paralelo es
necesario particionar la información en trozos, para que cada uno de estos, sea
tratado por un núcleo y luego volver a fusionar la información. Todo este
trabajo, conlleva un sobrecoste, que en ocasiones no es conveniente.