Historias de developers
Rate it:
Open Preview
Kindle Notes & Highlights
Read between January 13 - December 7, 2020
22%
Flag icon
tener cuidado con cosas que consideramos imposibles de alcanzar,
22%
Flag icon
experto en People Management
22%
Flag icon
adquirir un compromiso con nosotros mismos para llevar a cabo unas acciones cuyo beneficiario seremos nosotros mismos.
22%
Flag icon
analizar la situación actual en la que nos encontramos y la situación deseada en la que nos gustaría encontrarnos una vez hayamos podido conseguir nuestros objetivos.
22%
Flag icon
describamos claramente estos dos estados y que nos marquemos un plazo temporal
22%
Flag icon
nos desafía a lograr las metas
22%
Flag icon
definir una serie de tareas que contribuirán a su consecución. Estas tareas tienen que representar algo que realmente podamos hacer nosotros mismos,
22%
Flag icon
poner puntos de verificación intermedia, que pueden ayudarnos a ver cómo vamos y, si es necesario, a recalibrar las tareas.
22%
Flag icon
estimar lo que nos va a costar en tiempo y quién va a ser quien nos dé información sobre cómo lo estamos haciendo
22%
Flag icon
es muy importante que contrastemos lo que recibimos con nuestra percepción personal:
23%
Flag icon
un curso de formación vamos de asistentes más o menos activos, sin tener muy claro qué partes del curso nos beneficiarán más, qué partes menos.
23%
Flag icon
el plan de desarrollo individual nos comprometemos en ir aprendiendo mediante el trabajo en tareas concretas que realmente consideramos que facilitarán la consecución de nuestros objetivos.
23%
Flag icon
dueños absolutos de nuestras tareas, que podamos llevarlas a cabo de forma bastante autónoma y no dependamos de terceras partes cuyo rol quede poco definido.
23%
Flag icon
Si durante la ejecución nos damos cuenta que un objetivo ya está conseguido o que otro objetivo no lo vamos a poder abarcar, en la siguiente reunión de seguimiento podemos modificar nuestro plan consensuándolo con nuestro People Manager.
23%
Flag icon
sentimos que hemos realizado todo el esfuerzo posible para acometerlos. También éste es un ejercicio de aprendizaje, y lo que nos queda pendiente lo vamos a tener en cuenta de cara al siguiente plan que preparemos.
23%
Flag icon
“Visualiza tus objetivos”.
24%
Flag icon
La finalidad de un SCM es la de servir como punto de gestión de versiones relativamente estables, atómicas y completas del código.
24%
Flag icon
únicamente los cambios de código que pasan un cierto grado de medidas de calidad deben ser subidos al repositorio.
24%
Flag icon
servir de historial de los cambios realizados en el código.
24%
Flag icon
quién introdujo una determinada funcionalidad y cuándo lo hizo, cuándo se arregló un bug o problema, o cuántas veces se ha r...
This highlight has been truncated due to consecutive passage length restrictions.
24%
Flag icon
cuatro (o más) ojos ven mejor que dos
24%
Flag icon
las revisiones de código. Se trata de uno de los procesos más importantes a la hora de desarrollar software correcto y mantenible, y consiste en solicitar a uno o más miembros del equipo que revisen el código escrito.
24%
Flag icon
pre-commit y post-commit.
24%
Flag icon
las revisiones pre-commit tratan de identificar posibles bugs, aspectos que se podrían mejorar, inconsistencias en la arquitectura o el estilo de código, duplicidades,
24%
Flag icon
compartir el conocimiento del código entre los distintos miembros del equipo,
24%
Flag icon
las revisiones pre-commit introducen todas las ventajas del proceso de peer-reviewing (revisión en grupo). Esto es habitual en las publicaciones científicas y la programación extrema.
24%
Flag icon
facilita la tarea de tener commits controlados en las fases de estabilización del código.
25%
Flag icon
El ciclo de vida: estabilizar para triunfar
25%
Flag icon
Es importante que haya una o varias fases dedicadas a la estabilización del código, donde el objetivo es tratar de resolver problemas o fallos sin introducir funcionalidad nueva.
25%
Flag icon
El objetivo final de los procesos descritos en este documento es conseguir un ciclo de vida estricto con fases de desarrollo bien diferenciadas que permitan crear software estable y mantenible
25%
Flag icon
la programación funcional te hace más fuerte
25%
Flag icon
la programación funcional es una herramienta útil en el cinturón del programador imperativo aunque no se utilicen lenguajes funcionales
25%
Flag icon
lenguajes como LISP y ML,
25%
Flag icon
estilo de programación en el que la transparencia referencial permite explotar los poderosos medios de composición que son el orden superior y la evaluación perezosa.
25%
Flag icon
transparencia referencial
25%
Flag icon
las expresiones se puedan sustituir por su valor. En el caso de las funciones, éstas sólo dependerán de sus argumentos y que no tendrán más efecto que generar su valor devuelto. De lo con...
This highlight has been truncated due to consecutive passage length restrictions.
25%
Flag icon
es posible reemplazar la evaluación impaciente por otras estrategias como la evaluación perezosa en la que sólo se realizan los cálculos si el valor es realmente consumido y otras opciones más exóticas como la ejecución concurrente.
26%
Flag icon
Haskell,
26%
Flag icon
Estructuras de datos persistentes
26%
Flag icon
transparencia referencial a una estructura de datos lo que obtenemos son valores constantes o inmutables ya que no hay forma de modificar su estado una vez construidos.
27%
Flag icon
El orden superior que consiste en utilizar las funciones como ciudadanos de primera clase que pueden ser almacenadas en variables, pasadas como argumento o devueltas como resultado.
27%
Flag icon
La versatilidad del orden superior puede constatarse comprobando que muchos de los patrones GoF1 se implementan de forma trivial mediante este mecanismo.
27%
Flag icon
Strategy, Factory Method, Template Method, y Abstract Factory pueden ser directamente reemplazados por simples funciones
27%
Flag icon
Uno de los principales beneficios de la PF es que habilita nuevas formas de composición que conducen a módulos más pequeños y más poderosos.
27%
Flag icon
definir una biblioteca de funciones que encapsulen patrones típicos como transformar todos los elementos de una secuencia en otra (map), filtrar según un determinado predicado (filter) o realizar agregados (fold, sum). La clave radica en que estas funciones toman como argumento tanto las secuencias a manipular como funciones que modifican su comportamiento y que el resultado es componible de nuevo.
27%
Flag icon
facilidad para razonar sobre el código y sus relaciones, uno de los temas de fondo de las arquitecturas software.
27%
Flag icon
“locura es hacer la misma cosa una y otra vez esperando obtener diferentes resultados",
27%
Flag icon
la transparencia referencial reduce dramáticamente el coste de creación y mantenimiento de suites de tests a todos los niveles.
27%
Flag icon
un diseño con transparencia referencial tiene la ventaja de que las dependencias de datos entre funciones son explícitas y que su ejecución se puede realizar en paralelo sin mayor problema puesto que no es posible que haya dependencias ocultas. Además, las estructuras de datos inmutables presentan la ventaja de poder ser compartidas sin necesidad de establecer secciones críticas ni otros mecanismos de coordinación.
27%
Flag icon
el orden superior está presente en cada vez más lenguajes y su ausencia se puede suplir por medio de interfaces o clases plantilla. Por otro lado, la transparencia referencial se puede conseguir evitando las asignaciones y otros efectos laterales como decisión de diseño y la evaluación perezosa es posible con algo más de infraestructura con construcciones como generadores e iteradores.
1 5 11