Wartość dziesiętna
Mamy liczbę: 1.456 i chcemy pobrać wartość dziesiętną z tej liczby, czyli: *0.456". Jak to można zrobić?
Wartość można pobrać za pomocą operatora: %, w taki sposób:
1.456 % 1
Problem jest taki, że zwróci: 0.45599999999999996
Można to napisać tak:
+(1.456 % 1).toFixed(3)
Zwróci: 0.456
Za pomocą toFixed wyświetlamy liczbę z dokładnością do n miejsc po przecinku. Ponieważ toFixed zwraca wprawdzie liczbę, ale w postaci stringa, warto rzutować ją na liczbę za pomocą operatora +.
A co jeśli potrzebujesz się dowiedzieć, jaka jest wartość na drugim miejscu po przecinku?
Na przykład dla liczby: 2.52. Przykład:
+(2.52 % 0.1).toFixed(2)
Zwróci: 0.02
Czy tablica zawiera duplikaty?
const hasDuplicates = (data) => {
const result = new Set(data).size !== data.length;
return result;
}
console.log(hasDuplicates([1, 2, 3]);
console.log(hasDuplicates([1, 2, 3, 1]);
console.log(hasDuplicates(['a', 'b', 'c']);
console.log(hasDuplicates(['a', 'b', 'b']);
Cała sztuczka leży w użyciu Set. Po przekazaniu danych do Set pozbywasz się ewentualnych duplikatów. Dzięki temu zmieni się rozmiar zbioru i można to porównać z liczbą elementów z oryginalnej tablicy: data.
Czytelny kod
Kod częściej się czyta, niż pisze. Więc logiczne jest to, że warto skupić się na pisaniu kodu, który jest łatwo zrozumiały dla programisty.
Na czytelność kodu składa się kilka czynników, jak na przykład: odpowiednie nazewnictwo, liczba linijek kodu itp.
Innym ważnym czynnikiem jest złożoność kodu. Im bardziej kod jest złożony, tym trudniej się go czyta.
Jedną z metryk, która pozwala na zmierzenie złożoności kodu, jest: złożoność cyklomatyczna.
Złożoność cyklomatyczna
Informuje ona o liczbie ścieżek prowadzących w kodzie. Mierzy się ja w funkcji/metodzie.
Dzięki tej informacji wiesz nie tylko, jak bardzo złożona jest funkcja/metoda, ale także o minimalnej ilości testów potrzebnych do napisania, aby w pełni pokryć kod testami.
Minimalna wartość złożoności cyklomatycznej wynosi: 1.
Ile to za dużo?
Do jakiej wartości złożoności cyklomatycznej powinniśmy dążyć? Nie ma na to jasnej odpowiedzi, ale im mniejsza wartość, tym lepiej.
Autor książki: Zrównoważony kod. Dobre praktyki i heurystyki dla inżynierów oprogramowania — Mark Seemann proponuje, żeby maksymalna wartość wynosiła 7. Dlaczego akurat 7? Argumentuje to tym, że mózg człowieka dysponuje pamięcią krótko terminową. Jest ona ograniczona. Kiedy programista natrafia w metodzie na wiele instrukcji warunkowych lub/i pętli stara się "ogarnąć", jak działa ten kod. Im bardziej jest on złożony, tym trudniej go zrozumieć. Dlatego warto ograniczyć złożoność cyklomatyczną do stałej wartości i się tego konsekwentnie trzymać.
Jeśli złożoność cyklomatyczna wynosi więcej niż ustalona wartość powinieneś zrefaktorować kod, w wyniku czego ta wartość się zmniejszy.
Jak to policzyć?
Złożoność cyklomatyczną liczy się w prosty sposób: zaczynasz od wartości 1, licznik zwiększasz za każdym, gdy napotkasz w kodzie: instrukcje warunkowe i pętle.
Sam proces liczenia złożoności cyklomatycznej warto zautomatyzować, instalując na przykład jakąś bibliotekę do statycznej analizy kodu.
Przykłady
Przykład 1
function doSomething() {
console.log('Hello World!');
}
Złożoność cyklomatyczna wynosi: 1.
Przykład 2
function checkSomething(a) {
if (a > 5) {
return true;
}
return false;
}
Złożoność cyklomatyczna wynosi: 2.
Przykład 3
function iterate(max) {
let counter = 1;
while (counter <= max) {
console.log(`counter: ${counter}`);
counter++;
}
}
Złożoność cyklomatyczna wynosi: 2.
Przykład 4
function getColorInHex(color) {
switch(color) {
case 'red':
return '#ff0000';
case 'green':
return '#00ff00';
case 'blue':
return '#0000ff';
default:
return 'not found';
}
}
Złożoność cyklomatyczna wynosi: 5.
W przypadku instrukcji switch liczymy wszystkie case i default co daje nam: 1 + 4 = 5.
Przykład 5
function sayHello(name) {
let userName = name ?? 'stranger';
console.log(`Hello ${userName}!`);
}
Złożoność cyklomatyczna wynosi: 2.