Skip to content

ktrader-tech/jctp

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

29 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

JCTP

maven central jdk platform Apache License 2.0

基于 SWIG 实现的对上期技术 CTP 的封装。支持 64 位的 Windows 及 Linux 操作系统,动态链接库已被包含至 jar 包内,并在类加载时自动 loadLibrary,只需添加 jar 包即可直接使用。

如果你试图直接基于 CTP 开发交易策略程序,那么相比于繁琐、异步且充满各种坑的 CTP 原生接口,经过良好封装的 KTrader-Broker-CTP 会是一个更好的选择

当前已封装的 CTP 版本

6.7.2-1.0.5
6.7.2_CP-1.0.5
6.6.9-1.0.5
6.6.9_CP-1.0.5
6.6.1_P1-1.0.5
6.6.1_P1_CP-1.0.5
6.3.19_P1-1.0.5
6.3.19_T1-1.0.5

Usage

API 及使用方法同上期技术官方提供的 C++ 版 CTP SDK,另外使用前可以通过以下方法判断动态链接库是否已被成功加载:

import org.rationalityfrontline.jctp.*

fun main() {
    if (jctpJNI.libraryLoaded()) {
        // do something with CTP, here we print its sdk version
        println(CThostFtdcTraderApi.GetApiVersion())
        // release native gc root in jni, jctp will be unavailable after doing this
        jctpJNI.release()
    } else {
        System.err.println("Library load failed!")
    }
}

如果在 Linux 环境下使用,则需要确保已安装 zh_CN.GB18030 字符集:

sudo locale-gen zh_CN.GB18030

否则会报以下异常:

locale::facet::_S_create_c_locale name not valid

Download

Gradle Kotlin DSL:

repositories {
    mavenCentral()
}

dependencies {
    implementation("org.rationalityfrontline:jctp:6.7.2-1.0.5")
}

Maven:

<dependency>
    <groupId>org.rationalityfrontline</groupId>
    <artifactId>jctp</artifactId>
    <version>6.7.2-1.0.5</version>
</dependency>

Jar:

Maven Repository

使用 Jar 包前请先添加 native-lib-loader 依赖:

dependencies {
    implementation("org.scijava:native-lib-loader:2.5.0")
}

Build

前提要求(版本信息仅供参考,非必要):

  1. 安装 SWIG 4.0.2 并将其添加至环境变量中
  2. 安装 CMake > 3.16 并将其添加至环境变量中
  3. 安装 C++ 编译器( Windows 下是 msvc,Linux 下是 gcc/g++
  4. 安装 JDK 11 或以上的版本,并将其添加至环境变量中

Windows

build.cmd

Linux

./build.sh

以上为单平台版本编译,如需编译跨平台版本,则需要在两个平台下各编译一次(顺序随意)。

build 完毕后,生成的 jar 包在 java/build/libs 目录下。

Reference

https://blog.csdn.net/pjjing/article/details/53186394

http://www.swig.org/Doc4.0/Contents.html#Contents

https://github.com/scijava/native-lib-loader

License

JCTP is released under the Apache 2.0 license.

Copyright 2020-2024 RationalityFrontline

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

    http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.