+1 to Mon Key's suggestions. Those are very FAQ-like questions. -Matt On Dec 19, 12:45 am, Mon Key <s...@derbycityprints.com> wrote: > Some thoughts on really stupid things that have tripped me up: > > - How do I exit Clojure - srsly > C-c > > - Whatsa JVM - does this mean Clojure is really just Java with parens? > > - Whatsa Classpath? > this answer presents the *ALL* important opportunity to mention that > *nix uses `:' to separate paths whereas windz uses `;' > > - How do I access Clojure documentation - e.g. where is `man Clojure' > > - Is a Clojure docstring the same as Javadoc? > > - Is Clojure stable? > > - Where's the Clojure manual? > > - What happened to setf? > > - Why are Clojure's docstring placements different than other lisps > > - Where do I make donations? > > - Why are Clojure's defun params passed in a [] vector? > > - Does Clojure do TCO? > > - Whatsa TCO? > > - How do I compile Clojure? OR Where's the Clojure Compiler? > > - How does Clojure's nil differ from other Lisps? > > - Clojure has a `cons' function and a `conj' function - whats the > difference? > > - At what point do calls out to external Java interfaces limit/alter > Clojures' internal handling of sequences > ---- How do I avoid interopearating with Java - e.g. when is Clojure > all I need for task X > ---- When should I make use of external Java libraries > > - Whatsa Clojure Sequence - how does it corellate to language X > - Whatsa Collection - how does it corellate to language X > - Whatsa Map - how does it corellate to language X > > On Dec 19, 12:41 am, "Adrian Cuthbertson" > > <adrian.cuthbert...@gmail.com> wrote: > > > Suggestions for entries welcome here. > > > > > Rich > > > Here's another that was a "gotcha" for me for an hour or two... > > > Why after using map/reduce/for to change a java object does the object > > remain unchanged? > > > (defn initv1 [myseq] (let [v (java.util.Vector.)] (for [x myseq] > > (.addElement v x)) v)) > > (initv1 [1 2 3]) > > ; => (java.util.Vector. []) > > > ; or... > > > (defn initv2 [myseq] (let [v (java.util.Vector.)] (map (fn [x] (.addElement > > v x)) myseq) v)) > > (initv2 [1 2 3]) > > ; => (java.util.Vector. []) > > > As map/reduce/for are lazy, the "let" construct does not actually "take" any > > elements from the map/reduce/for. In this case, use doseq... > > > (defn initv3 [myseq] (let [v (java.util.Vector.)] (doseq [x myseq] > > (.addElement v x)) v)) > > (initv3 [1 2 3]) > > ; => (java.util.Vector. [1 2 3]) > > > (Actually this happened in a more complex function, but the essence was that > > a new java object was instantiated in a let and I'd used a map to call a > > method on that object with all the items from a sequence. I could not > > understand why the object remained unchanged afterwards until I simplified > > it down to the above example). > > > Regards, Adrian --~--~---------~--~----~------------~-------~--~----~ You received this message because you are subscribed to the Google Groups "Clojure" group. To post to this group, send email to clojure@googlegroups.com To unsubscribe from this group, send email to clojure+unsubscr...@googlegroups.com For more options, visit this group at http://groups.google.com/group/clojure?hl=en -~----------~----~----~----~------~----~------~--~---