You are viewing an old version of this page. View the current version. Compare with Current | View Page History
- Do I need to know Java to use Clojure?
Not at first, but it helps to know the standard Java APIs.
- Why can't I require/use my
Because here, your namespace is loaded from the disk. For good interop with JVM features, Clojure does some "munging/unmunging" of names depending of them having to be "consumed" by the "clojure side" or the "jvm side" of the equation. So a "_" in a namespace "folder name/file name" has to correspond to a "-" in the namespace name. Check that your namespace on disk is in "project_name/foo.clj", while your namespace is declared as "project-name.foo" (e.g. in a (ns project-name.foo) directive).
- Why doesn't
Because it expands to
#()always expands to include parens around the expression you give it. You might try
- Why doesn't
nthwork on sets and maps?
"There is a difference between a sequential view of a collection (i.e. what you get from seq) and the collection itself. Maps are not sequential data structures. nth is only supported for sequential data structures, and that is by design." – nth on maps thread
- How do you refer to a nested/inner class?
- Why doesn't
(. Integer getName)work?
. is a special operator. In particular, it does non-standard evaluation of its first arg. Because . can call static and instance methods, it determines if it is static call be seeing if the first arg names a class. In the case of
(. Integer getName), it tries to find the static getName member and doesn't, because there isn't one. You can use this syntax to call a static method on Integer:
(. Integer parseInt "42"). In short, if you can't say x.y() in Java you can't say (. x y) in Clojure, and you can't say Integer.getName() in Java.
- How do I call a Java method that takes a variable number of arguments?
The variable arguments are actually just an array:
- How do I get primitive types like
- When using
gen-class, how do I specify which method to override based on type signature?
This problem can appear if the class/interface you want to extend/implement defines methods with the same name and arity, only differing on the arguments types.
The solution is to suffix the function name in clojure with the types names, separated by slashes.
- Example1, the parent class/interface defines 2 methods : In clojure you'll write:
- Example2, the method to override has no argument, eg. . Then just append -void:
- Example3, case of a java array, specific syntax, eg. for overriding : You'll use the the-type<> syntax:
- How do I copy a file?
- Does Clojure support custom reader macros?
No, and support is not planned.