1
0
mirror of https://github.com/adambard/learnxinyminutes-docs.git synced 2025-01-17 13:38:38 +01:00

[clojure/ms-my] Remove asterisks from code comments (#2720)

* Remove asterisks from code comments

* Add backquote for emphasis as suggested in #2720
This commit is contained in:
Burhanuddin Baharuddin 2017-05-02 21:13:42 +08:00 committed by ven
parent 2aec020380
commit 77241749f8

View File

@ -20,20 +20,20 @@ dan kebiasaannya secara automatik.
```clojure ```clojure
; Komen bermula dengan koma bertitik (*semicolon*). ; Komen bermula dengan koma bertitik (semicolon).
; Clojure ditulis dalam bentuk yang seragam, iaitu ; Clojure ditulis dalam bentuk yang seragam, iaitu
; senarai perkataan di dalam kurungan (*parentheses*), dipisahkan dengan ruang kosong (*whitespace*). ; senarai perkataan di dalam kurungan (parentheses), dipisahkan dengan ruang kosong (whitespace).
; ;
; Pembaca Clojure akan menganggap bahawa perkataan pertama dalam senarai tersebut ; Pembaca Clojure akan menganggap bahawa perkataan pertama dalam senarai tersebut
; sebagai *function* atau *macro* untuk digunakan, dan yang selebihnya sebagai *arguments*. ; sebagai `function` atau `macro` untuk digunakan, dan yang selebihnya sebagai arguments.
; Panggilan pertama di dalam fail Clojure mestilah bermula dengan ns, untuk menentukan *namespace* ; Panggilan pertama di dalam fail Clojure mestilah bermula dengan ns, untuk menentukan `namespace`
(ns learnclojure) (ns learnclojure)
; Contoh-contoh asas yang lain: ; Contoh-contoh asas yang lain:
; str akan mewujudkan sebuah string daripada beberapa *argument* ; str akan mewujudkan sebuah string daripada beberapa `argument`
(str "Hello" " " "World") ; => "Hello World" (str "Hello" " " "World") ; => "Hello World"
; Operasi matematik pun mudah ; Operasi matematik pun mudah
@ -49,18 +49,18 @@ dan kebiasaannya secara automatik.
; Gunakan not untuk mengubah lojik ; Gunakan not untuk mengubah lojik
(not true) ; => false (not true) ; => false
; Bentuk *nested* berfungsi seperti yang dijangkakan ; Bentuk `nested` berfungsi seperti yang dijangkakan
(+ 1 (- 3 2)) ; = 1 + (3 - 2) => 2 (+ 1 (- 3 2)) ; = 1 + (3 - 2) => 2
; Type (Jenis Data) ; Type (Jenis Data)
;;;;;;;;;;;;; ;;;;;;;;;;;;;
; Clojure menggunakan jenis *object* dari Java untuk *boolean*, *string* dan nombor. ; Clojure menggunakan jenis `object` dari Java untuk `boolean`, `string` dan nombor.
; Gunakan `class` untuk memeriksa jenis sesebuah data. ; Gunakan `class` untuk memeriksa jenis sesebuah data.
(class 1) ; Secara *default* jenis data untuk Integer ialah java.lang.Long (class 1) ; Secara default jenis data untuk `Integer` ialah java.lang.Long
(class 1.); Jenis data untuk Float pula ialah java.lang.Double (class 1.); Jenis data untuk Float pula ialah java.lang.Double
(class ""); *String* sentiasa berada dalam tanda petikan (*quotation mark*), dan merupakan java.lang.String (class ""); `String` sentiasa berada dalam tanda petikan (quotation mark), dan merupakan java.lang.String
(class false) ; *Boolean* ialah java.lang.Boolean (class false) ; `Boolean` ialah java.lang.Boolean
(class nil); Nilai "null" dipanggil nil (class nil); Nilai "null" dipanggil nil
; Jika mahu membuat senarai data secara harfiah, gunakan ' untuk elakkan senarai tersebut ; Jika mahu membuat senarai data secara harfiah, gunakan ' untuk elakkan senarai tersebut
@ -74,17 +74,17 @@ dan kebiasaannya secara automatik.
; Collection & Sequence (Koleksi & Urutan) ; Collection & Sequence (Koleksi & Urutan)
;;;;;;;;;;;;;;;;;;; ;;;;;;;;;;;;;;;;;;;
; *List* ialah struktur data *linked-list*, manakala *Vector* pula berasaskan *array*. ; `List` ialah struktur data `linked-list`, manakala `Vector` pula berasaskan `array`.
; *Vector* dan *List* juga merupakan *class* dari Java! ; `Vector` dan `List` juga merupakan class dari Java!
(class [1 2 3]); => clojure.lang.PersistentVector (class [1 2 3]); => clojure.lang.PersistentVector
(class '(1 2 3)); => clojure.lang.PersistentList (class '(1 2 3)); => clojure.lang.PersistentList
; Sesebuah *list* boleh ditulis seperti (1 2 3), tetapi kita perlu meletakkan ' ; Sesebuah list boleh ditulis seperti (1 2 3), tetapi kita perlu meletakkan '
; untuk mengelakkannya daripada berfungsi. ; untuk mengelakkannya daripada berfungsi.
; Juga, (list 1 2 3) adalah sama dengan '(1 2 3) ; Juga, (list 1 2 3) adalah sama dengan '(1 2 3)
; "Collections" hanyalah kumpulan data ; "Collections" hanyalah kumpulan data
; Kedua-dua *list* dan *vector* ialah collection: ; Kedua-dua list dan vector ialah collection:
(coll? '(1 2 3)) ; => true (coll? '(1 2 3)) ; => true
(coll? [1 2 3]) ; => true (coll? [1 2 3]) ; => true
@ -94,7 +94,7 @@ dan kebiasaannya secara automatik.
(seq? [1 2 3]) ; => false (seq? [1 2 3]) ; => false
; Sesebuah seq hanya perlukan satu kemasukan data untuk diakses. ; Sesebuah seq hanya perlukan satu kemasukan data untuk diakses.
; Jadi, seq yang boleh jadi *lazy* (malas) -- boleh menjadi tidak terkira (*infinite*): ; Jadi, seq yang boleh jadi `lazy` (malas) -- boleh menjadi tidak terkira (infinite):
(range 4) ; => (0 1 2 3) (range 4) ; => (0 1 2 3)
(range) ; => (0 1 2 3 4 ...) (tiada penghujung) (range) ; => (0 1 2 3 4 ...) (tiada penghujung)
(take 4 (range)) ; (0 1 2 3) (take 4 (range)) ; (0 1 2 3)
@ -128,7 +128,7 @@ dan kebiasaannya secara automatik.
; Function ; Function
;;;;;;;;;;;;;;;;;;;;; ;;;;;;;;;;;;;;;;;;;;;
; Gunakan fn untuk membuat *function*. Sesebuah function pasti memulangkan semula ; Gunakan fn untuk membuat `function`. Sesebuah function pasti memulangkan semula
; hasil daripada barisan yang terakhir. ; hasil daripada barisan yang terakhir.
(fn [] "Hello World") ; => fn (fn [] "Hello World") ; => fn
@ -177,7 +177,7 @@ x ; => 1
; Map ; Map
;;;;;;;;;; ;;;;;;;;;;
; Hash map dan array map menggunakan *interface* yang sama. Hash map lebih laju untuk diakses ; Hash map dan array map menggunakan `interface` yang sama. Hash map lebih laju untuk diakses
; tetapi tidak mengekalkan urutan. ; tetapi tidak mengekalkan urutan.
(class {:a 1 :b 2 :c 3}) ; => clojure.lang.PersistentArrayMap (class {:a 1 :b 2 :c 3}) ; => clojure.lang.PersistentArrayMap
(class (hash-map :a 1 :b 2 :c 3)) ; => clojure.lang.PersistentHashMap (class (hash-map :a 1 :b 2 :c 3)) ; => clojure.lang.PersistentHashMap
@ -214,7 +214,7 @@ keymap ; => {:a 1, :c 3, :b 2}
(def newkeymap (assoc keymap :d 4)) (def newkeymap (assoc keymap :d 4))
newkeymap ; => {:a 1, :b 2, :c 3, :d 4} newkeymap ; => {:a 1, :b 2, :c 3, :d 4}
; Tetapi ingat, data dalam clojure adalah *immutable* (tidak berubah)! ; Tetapi ingat, data dalam clojure adalah `immutable` (tidak berubah)!
keymap ; => {:a 1, :b 2, :c 3} keymap ; => {:a 1, :b 2, :c 3}
; Gunakan dissoc untuk membuang key ; Gunakan dissoc untuk membuang key
@ -267,7 +267,7 @@ keymap ; => {:a 1, :b 2, :c 3}
(str "Hello " name)) ; => "Hello Urkel" (prints "Saying hello to Urkel") (str "Hello " name)) ; => "Hello Urkel" (prints "Saying hello to Urkel")
; Gunakan *threading macro* (-> dan ->>) untuk menulis penggubahan data ; Gunakan `threading macro` (-> dan ->>) untuk menulis penggubahan data
; dengan lebih jelas. ; dengan lebih jelas.
; Macro "thread-first" (->) memasukkan hasil perkiraan ke setiap form ; Macro "thread-first" (->) memasukkan hasil perkiraan ke setiap form