© 2015-2024. MindStreamAnalytics.com

Consejos de rendimiento de reglas de negocio de OneStream:

subprocesos múltiples para bucles en C# y VB.NET

Con los servidores con procesadores multinúcleo actuales, el uso de programación simultánea puede aumentar significativamente el rendimiento de su Código de Reglas de Negocio. Un escenario común donde brilla la simultaneidad es recorrer grandes conjuntos de datos o realizar tareas repetitivas. Al utilizar múltiples subprocesos en estos bucles, podemos dividir y conquistar, procesando fragmentos de datos en paralelo. En esta publicación, analizaremos el "cómo" y el "por qué" de los bucles for de subprocesos múltiples en las reglas comerciales de C# y VB.NET.

¿Por qué utilizar subprocesos múltiples?

  • 1. Rendimiento: en aplicaciones que requieren operaciones extensas vinculadas a la CPU, como cálculos en un bucle, subprocesos múltiples puede explotar múltiples núcleos de una CPU, ejecutando procesos simultáneamente y mejorando la velocidad de ejecución general.
  • 2. Capacidad de respuesta: en las aplicaciones de interfaz de usuario, descargar bucles que consumen mucho tiempo a un hilo separado mantiene la capacidad de respuesta de la interfaz de usuario. Esto garantiza que la aplicación siga siendo fácil de usar, incluso durante procesos intensivos.
  • 3. Utilización de recursos: el subproceso múltiple puede optimizar la utilización de recursos. Garantiza que mientras un hilo está esperando recursos (por ejemplo, operaciones de E/S), otro puede continuar ejecutándose, asegurando que la CPU no esté inactiva.

¿Cómo crear bucles For multiproceso?

.NET ofrece varias herramientas para el paralelismo, pero en aras de la simplicidad, nos centraremos en el método Parallel.For proporcionado. por el espacio de nombres System.Threading.Tasks.

Ejemplo de VB.NET:

Tomemos un bucle for simple que realiza algunas operaciones síncronas, una a la vez, vinculadas a la CPU:

Para realizar múltiples subprocesos en este bucle utilizando Parallel.For, el código se convierte en:

Ejemplo de C#:

Cosas a tener en cuenta:

  • 1. No siempre es más rápido: la introducción del paralelismo añade gastos generales. Para ciclos o tareas pequeños, los gastos generales pueden anular los beneficios, incluso ralentizando la ejecución. Siempre perfile/cronometre su aplicación para ver si el multiproceso ofrece beneficios reales.
  • 2. Seguridad de subprocesos: cuando varios subprocesos pueden acceder a datos compartidos simultáneamente, pueden ocurrir condiciones de carrera. Asegúrese de que su las operaciones dentro del bucle son seguras para subprocesos. Si es necesario, utilice bloqueos, pero tenga cuidado con posibles puntos muertos.
  • 3. Grado máximo de paralelismo: de forma predeterminada, Parallel.For utiliza tantos núcleos de sistema como estén disponibles. Sin embargo, es posible que no quieras utilizar todos los núcleos, especialmente en un sistema compartido. Controle esto configurando MaxDegreeOfParallelism:

Ordenado: La ejecución paralela no garantiza que las iteraciones se ejecutarán en orden. Si realizar el pedido es crucial, reconsidere si el paralelismo es la opción correcta para su bucle.

En conclusión, los bucles for de subprocesos múltiples tanto en C# como en VB.NET pueden ser una herramienta poderosa para mejorar el rendimiento, especialmente en Escenarios vinculados a la CPU. Sin embargo, como todas las herramientas, debe usarse con prudencia y apropiadamente, considerando la seguridad del hilo y la necesidades específicas de la aplicación. Intente utilizar un bucle for paralelo en su regla y observe el cambio en el rendimiento.

Socio destacado

OneStream se alinea con las necesidades de su negocio y cambia más rápida y fácilmente que cualquier otro producto al ofrecer una plataforma y un modelo para todas las soluciones financieras de CPM. OneStream emplea guiado Flujos de trabajo, validaciones y mapeo flexible para brindar confianza en la calidad de los datos para todas las recopilaciones y análisis al tiempo que se reduce el riesgo a lo largo de todo el proceso financiero auditable.

OneStream Profile

Estudios de caso

Accumen

Gracias a la intervención de MindStream Analytics, el departamento de Finanzas de Accumen ahora puede modelar su negocio con una estructura nueva y más organizada que no está disponible convencionalmente en NetSuite.

Acme Brick

Acme Brick recurrió a MindStream Analytics en busca de ayuda para implementar OneStream para reemplazar su obsoleta solución TM1.

Alterra

Alterra buscó la experiencia de MindStream para abordar los desafíos que enfrentaron en su proceso de planificación de capital.

ATCO Group

El conglomerado energético ATCO opera en todo el mundo en servicios públicos, generación de energía y servicios relacionados.

Avalon

Al trabajar con MindStream Analytics, Avalon Healthcare Solutions adopta NetSuite Planning and Budgeting para acelerar los procesos de presupuestación y previsión.

Bayer Health Care

Bayer Healthcare implementó Hyperion Planning y Workforce Planning en 10 semanas para optimizar drásticamente su presupuesto de declaración de ingresos y su proceso de planificación de la fuerza laboral.

BluEarth

La asociación de MindStream Analytics con BluEarth Renewables personifica el poder de la tecnología y la colaboración.

Celgene

Una actualización de planificación de Oracle Hyperion proporciona optimización y estabilización de la aplicación Hyperion de organizaciones multinacionales.

Cleaver Brooks

Se eligió OneStream XF como la plataforma que transformaría los procesos financieros de Cleaver-Brooks.

CoorsTek

La colaboración entre CoorsTek y MindStream dio como resultado mejoras significativas en los procesos de informes y consolidación financiera de CoorsTek.

Elite Body Sculpture

La colaboración de MindStream Analytics con Elite Body Sculpture resume el potencial transformador de las soluciones tecnológicas específicas para agilizar los procesos administrativos.

Enlyte

Enlyte, una fusión de Mitchell, Genex y Coventry, enfrentó desafíos con soluciones financieras dispares y la necesidad de informes combinados.

Flanders

MindStream Analytics colaboró ​​con Flanders para implementar la solución OneStream Consolidation and Reporting.

Productos Foley

Foley Products se enfrentaba a un desafío importante con su sistema de informes de gestión real basado en Excel.

Harte Hanks

La colaboración entre MindStream Analytics y Harte Hanks culminó en una implementación de NetSuite altamente personalizada y fácil de usar.

Interface

La interfaz utilizó un proceso de FP&A complejo, manual y basado en Excel para la revisión mensual, y los datos resumidos se cargaron en OneStream.

Kymera Internacional

Gracias a la asistencia de Mindstream Analytics, Kymera pudo cargar todos sus datos en OneStream y validarlos exitosamente.

MacLean Fogg

MacLean-Fogg se asoció con MindStream, un implementador líder que se especializa en modernizar y optimizar sistemas empresariales.

MEPPI

Se buscaron los conocimientos y la experiencia de MindStream para llevar a cabo una iniciativa de selección de proveedores centrada en el proceso de planificación F2023 de MEPPI.

OUAI

La colaboración de MindStream Analytics y OUAI muestra el poder transformador de la intervención tecnológica estratégica.

Plaskolite

Al migrar a OneStream, Plaskolite logró una reducción sustancial en el tiempo de consolidación y el ciclo general de cierre financiero, eliminó las horas dedicadas a compilar y verificar datos en Excel, agilizó su modelo de planificación, presupuestación y previsión y entregó informes flexibles y oportunos que permiten un análisis más estratégico de sus datos financieros.

Redwire

Al comprender los matices de los desafíos de Redwire, MindStream Analytics ideó un enfoque holístico para superarlos. La implementación de NetSuite fue sólo el comienzo.

Simon

La aplicación de producción corporativa Hyperion Financial Management (HFM) existente de Simon se estaba consolidando a un ritmo de siete horas, un problema de rendimiento que causaba un gran dolor de cabeza a la contabilidad corporativa.

Source Code

La transición exitosa a OneStream revolucionó los informes financieros de Source Code.

Subway

Subway colaboró ​​con MindStream Analytics para la implementación de NetSuite Analytics Warehouse.

UPenn

Los miembros del equipo de MindStream Consulting y AppCare están orgullosos de trabajar codo con codo con la Universidad de UPenn para lograr esta implementación y continuar con nuestros servicios de AppCare después de su puesta en marcha.

USG

USG era un cliente de Oracle Hyperion y se dio cuenta de que necesitaba soporte más especializado para sus diversas aplicaciones de Oracle Hyperion.

Vantiv

¿Dividir una aplicación de planificación de Hyperion y ampliar la huella de Hyperion para pronosticar el negocio? Categorías de clientes.

Versant Health

Versant Health contrató a MindStream para ayudar a resolver los desafíos que estaban experimentando con sus procesos de consolidación, cierre e informes financieros.

Virginia Space Authority

El equipo de MindStream implementó Standard + Workforce NetSuite Planning & Budgeting.

WeWork

MindStream Analytics determinó que la mejor solución era implementar Oracle Essbase Cloud como parte de la plataforma como servicio Oracle Analytics Cloud (OAC).

WindStream

Uso innovador de essbase para optimizar y conectar la gestión financiera de Hyperion para mejorar el análisis financiero.

XY Planning

MindStream Analytics, experto en abordar estos desafíos, presentó una solución integral de Netsuite para XY Planning.

Enlaces Relacionados