java扩展包_CodeRunner 的 Java 扩展 Jar 包支持

article/2025/8/9 0:41:47

CodeRunner 介绍

CodeRunner 是 Mac 上一款功能强大但使用简单代码工具,官方介绍支持几乎所有语言(20种语言),同时支持语法高亮、代码提示和多种界面主题,在学习新的语言或编写简单测试代码时非常实用。

我常常用它来管理一些代码片段和测试不确定的语言特性以及测试第三方开发包的接口行为。但 CodeRunner 并不是一个完整的 IDE,仅仅只能编译和运行单个文件,很多时候我们可能需要用编写并编译多个源文件或包含第三方库,这时候 CodeRunner 就完成不了了。所幸,CodeRunner 支持语言扩充,下面我们以 Java 为例,介绍支持多个 java 文件并导入第三方 jar 包。

扩充Java支持

首先,打开 CodeRunner 点击菜单 Preferences -> Languages ,从左侧列表中找到 Java,点击下面的齿轮按钮,选择 Duplicate ,将其命名为Java Ext。

d7dffea0c469

img_01.png

这样我们就复制了一份 Java 语言支持,在此基础上我们修改使其支持多个源文件和包含 jar 包。点击右侧的 Edit Script... 按钮,此时会在 CodeRunner 的编辑器内打开编译脚本 compile.sh ,这个脚本定义了如何编译 java 文件。我们只需要修改该脚本文件使其按我们期望的方式编译源文件并正确运行即可,我们的期望是--编译文件所在目录下面所有的源文件,并链接该目录下所有的 jar 包。

首先,我们需要指示编译脚本编译所有 java 文件。

最简单的处理方法是使用通配符 *.java,我们只需找到下列行:

CR_FILENAME="$packageDirectory"/"$CR_FILENAME"

替换为:

CR_FILENAME="$packageDirectory"/*.java

这样,编译时就会将源文件所在目录下的所有 java 文件都编译了。

接下来我们需要链接目录下面所有的 jar 文件。

我们只需要搜索当前目录下所有的jar 文件,并把他加到 classpath 中(在 java 执行时,如需要引用 jar 包,同时必须将 . 加入到 classpath 中),下面的脚本可以完成这件事:

find . "(" -name "." -or -name "*.jar" ")" | sed '$!N;s/\n/:/g'

我们把他添加到脚本中,找到下面这行:

javac "$CR_FILENAME" -encoding ${enc[$CR_ENCODING]} "${@:1}"

在之前添加 CLASSPATH 变量,并添加编译参数:

CLASSPATH=`find . "(" -name "." -or -name "*.jar" ")" | sed '$!N;s/\n/:/g'`

javac "$CR_FILENAME" -encoding ${enc[$CR_ENCODING]} -classpath "$CLASSPATH" "${@:1}"

同样,在编译完成后执行时,也需要引用 CLASSPATH。

因此,我们找到下面这行:

echo "cd \"$PWD\"; java $out"

添加 -classpath 参数:

echo "cd \"$PWD\"; java -classpath $CLASSPATH $out"

保存并关闭脚本编辑,完成。

此时,我们就已经建立一个新的语言支持 Java Ext,它能够编译同一文件夹内的多个源文件并自动链接该文件夹下的 jar 文件。

测试

我们以 fastjson 为例测试 Java Ext 的支持。

新建一个文件夹 TestFastjson ,将下载的 fastjson 包复制到文件夹内。

打开 CodeRunner 新建一个文件,选择语言 Java Ext,将生成模版的类名改为 FTClass,command+s 将文件命名为 FTClass.java 保存到刚刚新建的目录下。

新建另一个文件,改为 User 类,内容如下:

import com.alibaba.fastjson.annotation.JSONField;

class User {

@JSONField(name = "USER_ID")

private String userId;

@JSONField(name = "USER_NAME")

private String userName;

public String getUserId() {

return userId;

}

public void setUserId(String userId) {

this.userId = userId;

}

public String getUserName() {

return userName;

}

public void setUserName(String userName) {

this.userName = userName;

}

}

同样保存到新建的目录下,这里我们已经 import 了 fastjson 的包。

回到 FTClass.java 文件,我们添加一些简单的测试代码:

import com.alibaba.fastjson.*;

import java.util.*;

class FTClass {

public static void main(String[] args) {

User user = new User();

user.setUserId("admin");

user.setUserName("Creaman Xu");

System.out.print(JSON.toJSONString(user));

}

}

command+s 保存。

现在我们的测试文件夹应该有三个文件:

d7dffea0c469

img_02.png

点击运行,命令行能够正确的输出:

d7dffea0c469

img_03.png

说明 Java Ext 可以正常工作了。

I/O Encoding

如果产生错误,有时候命令行会打印乱码,那是因为 java 默认输出是 UTF8 编码,但 CodeRunner 使用的默认编码格式不是 UTF8,我们可以在设置中将其改为 UTF8,这样就不会产生乱码了。

d7dffea0c469

img_04.png

后记

CodeRunner 仅仅是一个非常方便的代码测试和学习的工具,它并不是一个完整的 IDE,在功能上还不是十分的完整,例如不支持 package,但仅仅作为一个代码测试工具真的是非常易用和方便了,而且,价格也不贵。


http://chatgpt.dhexx.cn/article/OpJBcFNK.shtml

相关文章

vscode 中 coderunner无法运行dart程序

如果你的vscode使用了CodeRunner,运行dart文件出错找不到dart的情况下: /bin/sh: dart: command not found可以直接修改coderunner扩展配置信息, 将其路径改为你希望的位置

vscode使用codeRunner将c/c++程序运行到外部控制台窗口

需要先关闭codeRunner的Run in Terminal 只需要在codeRunner的setting中,在从c/c的设置命令中添加 start cmd /c //或者/k /** 如果添加的是/c,则需要在程序的末尾添加system("pause"),不然会一闪而过, /k则不需要,不…

CodeRunner破解

CodeRunner2是Mac系统下的一款编程软件,支持23种语言和.txt文档制作,比Xcode都强大,Xcode只支持4种语言,原来的破解补丁有联网验证的问题,现在我做了程序防止联网验证。 破解方法:先下载CodeRunner2&#x…

windows系统VS code coderunner 运行shell脚本

无需设置环境变量,即可运行。 shell脚本第一行不要指定shell,什么“#!/bin/bash"不要写,这个会覆盖掉coderunner的设置。 在vs code设置中搜索“Code-runner: Executor Map” 点击“在setting.json中编辑” 修改shellscript后面引号里…

macOS使用CodeRunner快速配置fortran环境

个人网站:xzajyjs.cn 由于一些项目的缘故,需要有fortran的需求,但由于是M1 mac的缘故,不能像windows那样直接使用vsivf这种经典配置。搜了一下网上主流的跨平台方案,主要是gfortran,最近用Coderunner(主要…

coderunner运行c语言提示错误,vscode安装及使用coderunner运行C程序教程

vscode简介 ​ vscode 全称 visual studio code,是一个运行于 OS X,Windows 和 Linux 之上的,针对于编写现代web和云应用的跨平台编辑器。除了上述提到的,它在c/c的编写上也有非常优秀的表现,并且有着十分友好的快捷键…

vscode_CodeRunner_tempCodeRunnerFile是个啥?

文章目录 是你选中的代码片段后,按下了codeRunner快捷键后创建的文件 是你选中的代码片段后,按下了codeRunner快捷键后创建的文件 这个运行选中代码片段的功能不是很常(实)用,不过知道怎么规避这种文件的创建就可以了(即,运行是不要选中编辑器中的代码片段)

windows 下vscode coderunner+bash 编程

起因是学弟按照教程配置gcc,g无果。编译还是出问题,coderunner的原理是在终端运行命令,我索性用wsl的bash替换原始的终端。 首先安装wsl。 如果点击打开出现 WslRegisterDistribution failed with error: 0x8007019e 管理员打开powershell 输入 Enab…

coderunner:Mac上一个超好用的code编辑运行工具分享给大家!

Coderunner作为一个代码编辑器,却具备执行脚本的功能。 下载途径: 解决mac系统python 2.7,安装python3后终端仍旧是调用python 2.7的问题 安装python后,发现有一些工具包还需要安装。如果在mac自带的终端中执行这段代码&#xff…

VSCode插件---Code Runner

Code Runner: 代码一键运行,支持超过40种语言 工欲善其事必先利其器,vscode作为代码编辑器已经在工程师中成为了主流,大量的可供选择的插件也为工程师提供了丰富的扩展支持。而Code Runner应该是下载量最大的插件之一了,代码一键…

【VS Code 神奇小插件】Code Runner

文章目录 前言Code Runner简介Code Runner安装Code Runner编译中文乱码问题CodeRunner编译中文乱码问题解决方案 前言 如果没有猜错大家电脑上是不是安装了很多编程环境,Pycharm、IDEA、VS studio2022.....,这些都是项目集成环境,通常我们只会使用一门语…

Code Runner使用说明(快速运行调试代码,无需配置繁杂的环境)

文章目录 **前言**介绍特征: 安装在线安装:离线安装: 使用运行代码:停止正在运行的代码:仅运行指定代码:C示例:C示例:lua示例:python示例:GO示例:…

SQL内置函数日期函数

日期函数 基本的四个获取时间的函数 日期表达式又包括 大部分取之与英文翻译例题 1.查询所有学生的出生年份与姓名 select sname,year(birthday) as 出生年份 from t_student 2.查询显示所有学生的姓名与年龄 //思路:获取当前年份减去出生年份 select sname, y…

SQL中的日期差函数

Oracle: 计算日期之间的天数差 select TO_NUMBER((TO_DATE(2019-01-01 19:51:20,yyyy-mm-dd hh24:mi:ss)- TO_DATE(2019-01-05 21:50:20,yyyy-mm-dd hh24:mi:ss))*24) from dual;结果:4.0826388888888888888888888888888888889 会用第一个参数减去第二…

SQL Server 日期函数

今天介绍一下SQL Server中的日期函数,在数据库中有一种数据类型为date,该函数的作用就是查询这个数据类型,下面将举几个例子介绍时间函数中常用的几个函数 举例开始前我们先建立一个表,表名为time,在后面查询时使用 首…

【Hive SQL】常用日期函数汇总

目录 时间戳和日期相互转换函数: unix_timestamp :日期格式转换成时间戳 from_unixtime :时间戳转换成日期格式函数 current_timestamp: 获取当前的时间戳 to_date: 将日期由字符串类型转换成日期类型 转特定日期单位的函数:…

SQL Server函数的使用(日期函数和时间函数)

日期函数和时间函数 1… GetDate()函数 返回系统当前日期 – 返回当前系统的日期和时间 2.day函数 获取日期的’日’部分 day括号里面放的是日期 3.Month函数,返回日期中的月份 month括号里面放的是日期 4.Year函数,返回日期中的年份 year括号里面…

odps sql 日期函数处理

日期处理 to_date 命令格式: to_date(string, format)用途: 将一个字符串按照format指定的格式转成日期值。 SELECT to_date(20200401,yyyymmdd); > 2020-04-01 00:00:00to_char 命令格式: to_char(datetime, format)用途:…

关于sql中处理日期的相关函数

总结工作中用到的SQL 热门SQL下面是一些mysql的时间获取语句:处理时间的函数获取月份、星期、星期数、天数等函数日期的操作函数EXTRACT获取当年有多少天、当前日期已过去天数、获取当前年起始日期字符串转换为日期格式将时间、日期转换为字符串 日期转换函数、时间…

SQL 常用函数整理_日期函数(一)

SQL日期函数 1、DATEADD 函数作用:按照指定的单位datepart和幅度delta修改date的值。 语法示例:dateadd(datetime date, bigint delta, string datepart) 参数说明: date:Datetime类型,日期值。若输入为String类型…