Javadoc注释中的多行代码示例

我有一个小的代码示例,我想在方法的Javadoc注释中包括它。

/**
 * -- ex: looping through List of Map objects --
 * <code>
 * for (int i = 0; i < list.size(); i++) {
 *      Map map = (Map)list.get(i);
 *      System.out.println(map.get("wordID"));
 *      System.out.println(map.get("word"));
 * }
 * </code>
 * 
 * @param query - select statement
 * @return List of Map objects
 */

问题是代码示例显示在Javadoc中,没有换行符,很难阅读。

-- ex: looping through List of Map objects -- for (int i = 0; i list.size(); i++) { Map map = (Map)list.get(i); System.out.println(map.get("wordID")); System.out.println(map.get("word")); } 
Parameters
query - - select statement 
Returns:
List of Map objects 

我猜我认为代码标签可以处理换行符是错误的。格式化Javadoc注释中的代码示例的最佳方法是什么?

小宇宙猿2020/03/18 19:54:47

使用Java SE 1.6,看起来所有UPPERCASE PRE标识符都是在Javadoc中执行此操作的最佳方法:

/**
 * <PRE>
 * insert code as you would anywhere else
 * </PRE>
 */

是执行此操作的最简单方法。

我从java.awt.Event方法获得的javadoc示例:

/**
 * <PRE>
 *    int onmask = SHIFT_DOWN_MASK | BUTTON1_DOWN_MASK;
 *    int offmask = CTRL_DOWN_MASK;
 *    if ((event.getModifiersEx() & (onmask | offmask)) == onmask) {
 *        ...
 *    }
 * </PRE>
 */

这将产生与常规代码完全相似的输出,并保留常规代码间距和换行符。

阿飞Tony2020/03/18 19:54:47

我用<pre class="brush: java"></pre>标记将示例代码括起来并对已发布的javadocs 使用SyntaxHighlighter它不会损害IDE,并使发布的代码示例漂亮。

三千曜米亚2020/03/18 19:54:47

至少在Visual Studio Code中,您可以通过将Javadoc注释包装在三个反引号中来强制Javadoc注释遵守换行符,如下所示:

/** ```markdown
 * This content is rendered in (partial) markdown.
 * 
 * For example, *italic* and **bold** text works, but [links](https://www.google.com) do not.
 * Bonus: it keeps single line-breaks, as seen between this line and the previous.
 ``` */
西里神无Pro2020/03/18 19:54:47

我只是在这里阅读Javadoc 1.5参考,并且只将带有<的代码>包含在其中{@code ...}这里有个简单的例子:

 /** 
 * Bla bla bla, for example:
 *
 * <pre>
 * void X() {
 *    List{@code <String>} a = ...;
 *    ...
 * }
 * </pre>
 *
 * @param ...
 * @return ...
 */
 .... your code then goes here ...
小小猪猪2020/03/18 19:54:47

尝试用“ pre”替换“ code”。HTML中的pre标签将文本标记为预格式化,并且所有换行符和空格将在您键入时完全显示。

小胖逆天2020/03/18 19:54:47

之间的区别很大<blockquote><pre>...<pre>{@code....前者将省略泛型中的类型声明,而后者将保留它。

E.g.: List<MyClass> myObject = null; 显示为List myObject = null;与firts并作为List<MyClass> myObject = null;与所述第二

村村伽罗十三2020/03/18 19:54:47

我可以使用代码1中显示的以下片段生成美观的HTML文件。

 * <pre>
 * {@code
 * A-->B
 *  \
 *   C-->D
 *    \   \
 *     G   E-->F
 * }
 *</pre>

(代码1)

如预期的那样,代码1变成了图1中生成的javadoc HTML页面。

A-->B
 \
  C-->D
   \   \
    G   E-->F

(图。1)

但是,在NetBeans 7.2中,如果您按Alt + Shift + F(重新格式化当前文件),则代码1会变成代码2。

 * <
 * pre>
 * {@code
 * A-->B
 *  \
 *   C-->D
 *    \   \
 *     G   E-->F
 * }
 * </pre>

(代码2)

<pre>现在第一个分为两行。代码2生成生成的javadoc HTML文件,如图2所示。

< pre> A-->B \ C-->D \ \ G E-->F

(图2)

史蒂夫·B(Steve B)的建议(代码3)似乎给出了最好的结果,即使按了Alt + Shift + F也仍然保持预期的格式。

*<p><blockquote><pre>         
* A-->B
*  \
*   C-->D
*    \   \
*     G   E-->F
* </pre></blockquote>

(代码3)

使用代码3会产生与图1相同的javadoc HTML输出。

GreenStafan2020/03/18 19:54:47

如果您是Android开发人员,则可以使用:

<pre class=”prettyprint”>

TODO:your code.

</pre>

用Java代码在Javadoc中漂亮地打印代码。

逆天乐樱2020/03/18 19:54:47

这是我的两分钱。

正如其他答案已经指出的那样,您应该<pre> </pre>与结合使用{@code }

使用pre{@code}

  • 将您的代码包装在内部,<pre></pre>防止您的代码折叠成一行;
  • 将代码包装在内部{@code }可防止<>并且介于两者之间的所有内容都不会消失。当您的代码包含泛型或lambda表达式时,这特别有用。

注释问题

当您的代码块包含注释时,可能会出现问题。这可能是因为当@符号出现在Javadoc行的开头时,它被视为Javadoc标记,例如@param@return例如,此代码可能被错误地解析:

/**
 * Example usage:
 *
 * <pre>{@code
 * @Override
 * public void someOverriddenMethod() {

在我看来,以上代码将完全消失。

要解决此问题,该行不能以@符号开头

/**
 * Example usage:
 *
 * <pre>{@code  @Override
 * public int someMethod() {
 *     return 13 + 37;
 * }
 * }</pre>
 */

请注意,@code之间有两个空格@Override,以使内容与下一行对齐。就我而言(使用Apache Netbeans),它可以正确呈现。

小哥小卤蛋Tony2020/03/18 19:54:47

在Javadoc注释中包含特定的代码示例时,我经历了一段非常艰难的时期。我想分享这个。
请注意以下事项:

  • 使用<code>old-标签以防止大括号被解释
  • “ new”的用法{@code ...}-标记以获取包含在输出中的泛型
  • @Override通过“ {@literal @}Override转义@符号,因为javadoc生成器在此处“倾斜”,因为@紧接在大括号后
  • {@code和之前删除一个空格{@literal,以补偿内部空格并保持对齐

javadoc代码:

/** this methods adds a specific translator from one type to another type. `
  * i.e.
  * <pre>
  * <code>new BeanTranslator.Builder()
  *   .translate(
  *     new{@code Translator<String, Integer>}(String.class, Integer.class){
  *      {@literal @}Override
  *       public Integer translate(String instance) {
  *         return Integer.valueOf(instance);
  *       }})
  *   .build();
  * </code>
  * </pre>
  * @param translator
  */

被打印为

new BeanTranslator.Builder()
  .translate(
    new Translator<String, Integer>(String.class, Integer.class){
      @Override
      public Integer translate(String instance) {
        return Integer.valueOf(instance);
      }})
  .build();
凯村村乐2020/03/18 19:54:47

您需要<pre></pre>用于换行符标记,并在其{@code ... }内部使用泛型标记但是之后不允许将括号放在与<generic>标签相同的行上,因为这样所有内容将再次显示在1行上。

一行显示:

* ..
* <pre>
* {@code
* public List<Object> getObjects() {
*    return objects;
* }
* </pre>
* ..

显示带换行符:

* ..
* <pre>
* {@code
* public List<Object> getObjects() 
* {
*    return objects;
* }
* </pre>
* ..

另一个奇怪的事情是,当您粘贴的右括号时{@code,它会显示出来:

* ..
* <pre>
* {@code
*   public List<Object> getObjects() 
*   {
*     return objects;
*   }
* }
* </pre>
* ..

输出:

public List<Object> getObjects() 
{
   return objects;
}
}
小哥小宇宙2020/03/18 19:54:47

<pre></pre>标签将多行代码括起来

Stafan泡芙2020/03/18 19:54:47

除了已经提到的<pre>标签之外,您还应该使用@codeJavaDoc注释,当涉及到HTML实体问题(尤其是泛型)时,这将使工作变得更加轻松,例如:

* <pre>
* {@code
* Set<String> s;
* System.out.println(s);
* }
* </pre>

将给出正确的HTML输出:

Set<String> s;
System.out.println(s);

省略该@code块(或使用<code>标签)将导致如下所示的HTML:

Set s;
System.out.println(s);

(作为参考,可以在这里找到Java SE 8标记说明:Javadoc标记

逆天飞云2020/03/18 19:54:47
/**
 * <blockquote><pre>
 * {@code
 * public Foo(final Class<?> klass) {
 *     super();
 *     this.klass = klass;
 * }
 * }
 * </pre></blockquote>
 **/
  • <pre/> 保留线路是必需的。
  • {@code 必须有自己的路线
  • <blockquote/> 仅用于缩进。
public Foo(final Class<?> klass) {
    super();
    this.klass = klass;
}


使用JDK8更新

正确代码的最低要求为<pre/>{@code}

/**
 * test.
 *
 * <pre>{@code
 * <T> void test(Class<? super T> type) {
 *     System.out.printf("hello, world\n");
 * }
 * }</pre>
 */

产量

 <T> void test(Class<? super T> type) {
     System.out.printf("hello, world\n");
 }

可选的周围<blockquote/>插入一个缩进。

/**
 * test.
 *
 * <blockquote><pre>{@code
 * <T> void test(Class<? super T> type) {
 *     System.out.printf("hello, world\n");
 * }
 * }</pre></blockquote>
 */

产量

     <T> void test(Class<? super T> type) {
         System.out.printf("hello, world\n");
     }

插入<p>或将其包围<p></p>产生警告。