- yaml-cpp库
猿饵块
linux运维服务器
作用下载安装yaml-cpp库sudoaptinstalllibyaml-cpp-devCMakeLists.txt配置yaml-cpp依赖cmake_minimum_required(VERSION3.9.0)project(pro_judge_path)#set(path_to_third_party"${CMAKE_SOURCE_DIR}/third_party")find_package(
- git commit 自动修复 eslint 和 prettier
等下吃什么?
前端前端
npminstalllint-stagedeslintprettier--save-dev修改package.json"lint-staged":{"**/*.{js,jsx,ts,tsx,vue}":["prettier--write","eslint--fix"],"**/*.json":["prettier--write"],"**/*.{less,md}":["prettier--writ
- C++ linux下的cmake
陆地鲨鱼-彻
个人学习笔记c++开发语言
cmake是一个帮助我们构建项目的跨平台工具。让我们不需要一次次手动配置makefile,或者手动去链接库这些操作。配置(基于vscode编辑器)在项目main.cpp同级目录下,创建CMakeLists.txt文件,举例内容如下(需自己配置)://指定构建项目所需的最低cmake版本cmake_minimum_required(VERSION3.10)//指定工程的名字(随后输出的可执行文件与其
- 【c++实用】CMakeLists 基本用法(一)
黄小莫
c++
指令解释cmake_minimum_required(VERSION3.24):指令指定了所需的最低CMake版本a.作用:确保在执行CMake配置时,使用的CMake版本不低于3.24。如果安装的CMake版本低于指定的版本,CMake将会输出错误信息,并拒绝继续执行后续命令b.兼容性:有助于确保项目构建脚本中使用的特性或语法能够在目标环境中正确解析和执行。例如,某些新版本引入的功能在旧版本中可
- CMAKE中指定c++版本
nb的码农
c++开发语言
cmake_minimum_required(VERSION3.20)project(YourProjectName)set(CMAKE_CXX_STANDARD20)set(CMAKE_CXX_STANDARD_REQUIREDON)set(CMAKE_CXX_EXTENSIONSOFF)添加你的源文件add_executable(YourExecutablemain.cpp)
- [Cmake]cmake指定C++版本
刘好念
C++c++开发语言cmake
一、简介本文介绍了如何指定在使用cmake和make进行编译C++程序时指定所使用的C++版本。二、示例1.使用CMakeLists.txt指定CMakeLists.txt示例:cmake_minimum_required(VERSION3.5.0)project(HelloWorld)#指定使用C++17set(CMAKE_CXX_STANDARD17)#强制使用C++17,不可回退,如果编译器
- CMake指令
Covirtue
CMakeCMake
在CMake中,常用的指令对于定义项目的构建过程至关重要。以下是一些常用的CMake指令的详细解释:1.cmake_minimum_required作用:指定构建该项目所需的CMake最低版本。语法:cmake_minimum_required(VERSIONmajor.minor[PATCH[min_policy_version]])VERSION后跟的是所需的CMake版本号。PATCH和mi
- 备战秋招60天算法挑战,Day8
华南溜达虎
数据结构与算法算法
题目链接:https://leetcode.cn/problems/find-minimum-in-rotated-sorted-array/视频题解:https://www.bilibili.com/video/BV1VC41157ha/LeetCode153.寻找旋转排序数组中的最小值题目描述已知一个长度为n的数组,预先按照升序排列,经由1到n次旋转后,得到输入数组。例如,原数组nums=[0
- 云原生周刊:Kubernetes Grafana 看板更新 | 2024.5.13
KubeSphere 云原生
k8s容器平台kubesphere云计算
开源项目推荐ChartTestingChartTesting是用于测试Helm图表的工具。它旨在用于对拉取请求进行lint和测试。它会自动检测针对目标分支更改的图表。ClusterpediaClusterpedia是一个多集群的百科全书,用于同步、搜索和简单控制多集群资源。Clusterpedia可以与多个集群同步资源,并在与KubernetesOpenAPI兼容的基础上提供更强大的搜索功能,以帮
- CMakeLists.txt模板
Script kiddies
cmakec++
#设置编译该CMakeLists.txt文件所需要的最低cmake版本CMAKE_MINIMUM_REQUIRED(VERSION最低版本号)#该项目名称PROJECT(项目名称)SET(CMAKE_CXX_STANDARD11)SET(CMAKE_C_STANDARD11)#此行可以理解为将路径下所有的文件装载到自定义集合filelist中FILE(GLOBfilelist"${PROJECT_
- 64. 最小路径和(python3)
keep moving 123
leetcodemediumDPleetcode
题目:https://leetcode-cn.com/problems/minimum-path-sum/给定一个包含非负整数的mxn网格grid,请找出一条从左上角到右下角的路径,使得路径上的数字总和为最小。说明:每次只能向下或者向右移动一步。示例1:输入:grid=[[1,3,1],[1,5,1],[4,2,1]]输出:7解释:因为路径1→3→1→1→1的总和最小。示例2:输入:grid=[[
- Leetcode 3085. Minimum Deletions to Make String K-Special
Espresso Macchiato
leetcode笔记leetcode3085leetcode周赛389leetcodemediumleetcode题解滑动窗口
Leetcode3085.MinimumDeletionstoMakeStringK-Special1.解题思路2.代码实现题目链接:3085.MinimumDeletionstoMakeStringK-Special1.解题思路这一题思路上来说的话我们只需要统计一下word当中所有的字符出现的频次,然后依次排序,我们只需要考察各个删除方案使得所有存在的频次之间的差值不多于kkk即可。而对于各个具
- 一起学算法-1217. 玩筹码
Justin小贾同学
一、题目LeetCode-1217.玩筹码地址:https://leetcode-cn.com/problems/minimum-cost-to-move-chips-to-the-same-position/难度:简单数轴上放置了一些筹码,每个筹码的位置存在数组chips当中。你可以对任何筹码执行下面两种操作之一(不限操作次数,0次也可以):将第i个筹码向左或者右移动2个单位,代价为0。将第i个
- 使用Qt 6创建第一个CMAKE项目
大白菜66
QtC++c++cmakeqt
目录1.创建一个普通C++项目2.创建一个Qt项目3.CMake术语解释1.创建一个普通C++项目新建一个文件夹test用于本次项目的测试,新建两个文件分别为CMakeLists.txt和main.cxxCMkeLists.txtcmake_minimum_required(VERSION3.15)project(TestLANGUAGESCXX)add_executable(${PROJECT_
- LeetCode——1723. 完成所有工作的最短时间(Find Minimum Time to Finish All Jobs)[困难]——分析及代码(Java)
江南土豆
数据结构与算法LeetCodeJava题解
LeetCode——1723.完成所有工作的最短时间[FindMinimumTimetoFinishAllJobs][困难]——分析及代码[Java]一、题目二、分析及代码1.二分+回溯+剪枝(1)思路(2)代码(3)结果三、其他一、题目给你一个整数数组jobs,其中jobs[i]是完成第i项工作要花费的时间。请你将这些工作分配给k位工人。所有工作都应该分配给工人,且每项工作只能分配给一位工人。工
- LeetCode1723. 完成所有工作的最短时间 Java回溯+剪枝(详解)
oyzg
LeetCodejavaleetcode算法
1723.完成所有工作的最短时间链接:https://leetcode-cn.com/problems/find-minimum-time-to-finish-all-jobs/solution/javahui-su-jian-zhi-by-oyzg-409h/classSolution{/***最小的工人最大用时*/privateintminId=Integer.MAX_VALUE;public
- hdu 4408 Minimum Spanning Tree
luckycoding
hdu
题目连接:点击打开链接解法:利用kruskal算法把图划分成森林,同一点有相同最小的权值到别的点,通过determinant计算树的课数。总结:模板+自己不太懂=记录+重新学代码君:#include#include#include#defineLLlonglongusingnamespacestd;constintMAX=105;constintMAXE=1005;structnode{intse
- ROS篇——一个简单的ros package的编译规则CMakeLists.txt文件的编写示例
易Yi
ROS篇Ubuntu篇机器人linuxc++
package的文件结构如下:如上图的文件结构src中lidar.cpp是一个工具类,lidar_ros_node.cpp是最终要运行的可执行程序的代码。include中是lidar.cpp要用到的一些头文件。launch文件夹中是要运行的launch文件。则CMakeLists.txt文件可如下编写。cmake_minimum_required(VERSION3.0.2)project(lida
- 代码随想录刷题笔记-Day19
枯树老斑鸠
代码随想录笔记
1.二叉搜索树的最小绝对差530.二叉搜索树的最小绝对差https://leetcode.cn/problems/minimum-absolute-difference-in-bst/给你一个二叉搜索树的根节点root,返回树中任意两不同节点值之间的最小差值。差值是一个正数,其数值等于两值之差的绝对值。示例1:输入:root=[4,2,6,1,3]输出:1示例2:输入:root=[1,0,48,n
- Leetcode 64. 最小路径和 c++
让菜鸟飞
链接:https://leetcode-cn.com/problems/minimum-path-sum/主要思路:1.这个题比较简单,因为题目要求了,只能向右或者向下走,逐行遍历计算最短路径就可以了。2.第一行只能通过左侧的点计算最短路径,第一列只能通过上方的点计算最短路径。3.其它的点要对比左侧和上方最短路径选择最小的计算。classSolution{public:intminPathSum(
- 代码随想录算法训练营 DAY20 | 二叉树(7)
橙南花已开
代码随想录算法训练营算法
一、LeetCode530二叉搜索树的最小绝对值题目链接:530.二叉搜索树的最小绝对值https://leetcode.cn/problems/minimum-absolute-difference-in-bst/思路一:利用搜索二叉树的中序遍历结果为有序数组的性质,将遍历结果保存到数组中,再找最小绝对值。classSolution{Listlist=newLinkedListlist;intm
- Leetcode 333. Largest BST Subtree (二叉树后序遍历好题)
纸上得来终觉浅 绝知此事要躬行
leetcode算法职场和发展
LargestBSTSubtreeGivenabinarytree,findthelargestsubtreewhichisaBinarySearchTree(BST),wherelargestmeanssubtreewithlargestnumberofnodesinit.Note:Asubtreemustincludeallofitsdescendants.Example:Input:[10,
- React ts项目配置Eslint+StyleLint+prettier+husky+lint-staged规范
悟空Wukong95
下载相关依赖npminstalleslint@typescript-eslint/parser@typescript-eslint/eslint-pluginprettiereslint-config-prettiereslint-plugin-prettierstylelintstylelint-config-css-modulesstylelint-config-standardstyleli
- Qt6 cmake 调用静态库和共享库的方法
黄鱼脑干细胞
qt6
调用共享库:cmake_minimum_required(VERSION3.5)project(untitledVERSION0.1LANGUAGESCXX)set(CMAKE_AUTOUICON)set(CMAKE_AUTOMOCON)set(CMAKE_AUTORCCON)set(CMAKE_CXX_STANDARD17)set(CMAKE_CXX_STANDARD_REQUIREDON)fi
- python 笔记:shapely(形状篇)
UQI-LIUWJ
python库整理笔记
主要是点(point)、线(linestring)、面(surface)1基本方法和属性object.area返回对象的面积(浮点数)object.bounds返回一个(minx,miny,maxx,maxy)元组(浮点值),该元组界定了对象的边界object.length返回对象的长度(浮点数)object.minimum_clearance返回通过移动一个节点所能产生的无效几何形状的最小距离这
- Boost.Test-如何将测试套件(源码文件)组织成工程、并执行测试
爱丽J
Boost.Test
Boost.Test资源及示例的续篇1.测试套件TestSuite的源码文件组织如下图2.CMakeLists.txt需要自己编写,本例内容如下cmake_minimum_required(VERSION3.5.0FATAL_ERROR)project(mytestmodule)enable_testing()#indicatesthelocationoftheboostinstallationt
- C++ matplotlib 画图 Linux
Big David
matplotlib-cppc++matplotliblinux
Matplotlib-cpp画图命令行下载matplotlibcppgitclonehttps://github.com/lava/matplotlib-cpp将matplotlibcpp.h移动到自己所用的工程CMakeList.txt文件如下所示cmake_minimum_required(VERSION3.0.2)project(huatu)set(CMAKE_CXX_STANDARD11)
- 2021-1-24
宁_74ea
initial-scale:viewport的初始缩放级别(0-10之间的正数,1表示无缩放)minimum-scale:viewport能缩放的最小值(0-10之间的正数)maximum-scale:viewport能缩放的最大值(0-10之间的正数)user-scalable:是否可以手动缩放(yesorno)没有text-color这个属性,文字颜色统一用color.再加上就近原则autop
- 一. 使用perl对Soc中的digital ip进行lint check
Followex
#perl在ic设计中的应用perllanguageperl硬件架构开发语言
一.使用perl对Soc中的digitalip进行lintcheck1.purpose在SoC芯片设计中,需要用到很多的digitalip。在前端设计来到中后期时,在RTLsignoff之前,需要对rtl进行lintcheck,一般使用的是synopsys家的SpyGlass。如果一个个到对应的ip目录下runSpyGlass软件并查看输出报告是非常费事费力的,而且还不能确定万无一失。因此我们就可
- Linux服务器初次使用需要的环境配置
wyyyyyyyy_
Linux服务器linux网络
一、划分磁盘1.查看磁盘sudofdisk-lDisk/dev/sda:3.7TiB,4000787030016bytes,7814037168sectors//新增的硬盘Units:sectorsof1*512=512bytesSectorsize(logical/physical):512bytes/4096bytesI/Osize(minimum/optimal):4096bytes/409
- apache ftpserver-CentOS config
gengzg
apache
<server xmlns="http://mina.apache.org/ftpserver/spring/v1"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="
http://mina.apache.o
- 优化MySQL数据库性能的八种方法
AILIKES
sqlmysql
1、选取最适用的字段属性 MySQL可以很好的支持大数据量的存取,但是一般说来,数据库中的表越小,在它上面执行的查询也就会越快。因此,在创建表的时候,为了获得更好的 性能,我们可以将表中字段的宽度设得尽可能小。例如,在定义邮政编码这个字段时,如果将其设置为CHAR(255),显然给数据库增加了不必要的空间,甚至使用VARCHAR这种类型也是多余的,因为CHAR(6)就可以很
- JeeSite 企业信息化快速开发平台
Kai_Ge
JeeSite
JeeSite 企业信息化快速开发平台
平台简介
JeeSite是基于多个优秀的开源项目,高度整合封装而成的高效,高性能,强安全性的开源Java EE快速开发平台。
JeeSite本身是以Spring Framework为核心容器,Spring MVC为模型视图控制器,MyBatis为数据访问层, Apache Shiro为权限授权层,Ehcahe对常用数据进行缓存,Activit为工作流
- 通过Spring Mail Api发送邮件
120153216
邮件main
原文地址:http://www.open-open.com/lib/view/open1346857871615.html
使用Java Mail API来发送邮件也很容易实现,但是最近公司一个同事封装的邮件API实在让我无法接受,于是便打算改用Spring Mail API来发送邮件,顺便记录下这篇文章。 【Spring Mail API】
Spring Mail API都在org.spri
- Pysvn 程序员使用指南
2002wmj
SVN
源文件:http://ju.outofmemory.cn/entry/35762
这是一篇关于pysvn模块的指南.
完整和详细的API请参考 http://pysvn.tigris.org/docs/pysvn_prog_ref.html.
pysvn是操作Subversion版本控制的Python接口模块. 这个API接口可以管理一个工作副本, 查询档案库, 和同步两个.
该
- 在SQLSERVER中查找被阻塞和正在被阻塞的SQL
357029540
SQL Server
SELECT R.session_id AS BlockedSessionID ,
S.session_id AS BlockingSessionID ,
Q1.text AS Block
- Intent 常用的用法备忘
7454103
.netandroidGoogleBlogF#
Intent
应该算是Android中特有的东西。你可以在Intent中指定程序 要执行的动作(比如:view,edit,dial),以及程序执行到该动作时所需要的资料 。都指定好后,只要调用startActivity(),Android系统 会自动寻找最符合你指定要求的应用 程序,并执行该程序。
下面列出几种Intent 的用法
显示网页:
- Spring定时器时间配置
adminjun
spring时间配置定时器
红圈中的值由6个数字组成,中间用空格分隔。第一个数字表示定时任务执行时间的秒,第二个数字表示分钟,第三个数字表示小时,后面三个数字表示日,月,年,< xmlnamespace prefix ="o" ns ="urn:schemas-microsoft-com:office:office" />
测试的时候,由于是每天定时执行,所以后面三个数
- POJ 2421 Constructing Roads 最小生成树
aijuans
最小生成树
来源:http://poj.org/problem?id=2421
题意:还是给你n个点,然后求最小生成树。特殊之处在于有一些点之间已经连上了边。
思路:对于已经有边的点,特殊标记一下,加边的时候把这些边的权值赋值为0即可。这样就可以既保证这些边一定存在,又保证了所求的结果正确。
代码:
#include <iostream>
#include <cstdio>
- 重构笔记——提取方法(Extract Method)
ayaoxinchao
java重构提炼函数局部变量提取方法
提取方法(Extract Method)是最常用的重构手法之一。当看到一个方法过长或者方法很难让人理解其意图的时候,这时候就可以用提取方法这种重构手法。
下面是我学习这个重构手法的笔记:
提取方法看起来好像仅仅是将被提取方法中的一段代码,放到目标方法中。其实,当方法足够复杂的时候,提取方法也会变得复杂。当然,如果提取方法这种重构手法无法进行时,就可能需要选择其他
- 为UILabel添加点击事件
bewithme
UILabel
默认情况下UILabel是不支持点击事件的,网上查了查居然没有一个是完整的答案,现在我提供一个完整的代码。
UILabel *l = [[UILabel alloc] initWithFrame:CGRectMake(60, 0, listV.frame.size.width - 60, listV.frame.size.height)]
- NoSQL数据库之Redis数据库管理(PHP-REDIS实例)
bijian1013
redis数据库NoSQL
一.redis.php
<?php
//实例化
$redis = new Redis();
//连接服务器
$redis->connect("localhost");
//授权
$redis->auth("lamplijie");
//相关操
- SecureCRT使用备注
bingyingao
secureCRT每页行数
SecureCRT日志和卷屏行数设置
一、使用securecrt时,设置自动日志记录功能。
1、在C:\Program Files\SecureCRT\下新建一个文件夹(也就是你的CRT可执行文件的路径),命名为Logs;
2、点击Options -> Global Options -> Default Session -> Edite Default Sett
- 【Scala九】Scala核心三:泛型
bit1129
scala
泛型类
package spark.examples.scala.generics
class GenericClass[K, V](val k: K, val v: V) {
def print() {
println(k + "," + v)
}
}
object GenericClass {
def main(args: Arr
- 素数与音乐
bookjovi
素数数学haskell
由于一直在看haskell,不可避免的接触到了很多数学知识,其中数论最多,如素数,斐波那契数列等,很多在学生时代无法理解的数学现在似乎也能领悟到那么一点。
闲暇之余,从图书馆找了<<The music of primes>>和<<世界数学通史>>读了几遍。其中素数的音乐这本书与软件界熟知的&l
- Java-Collections Framework学习与总结-IdentityHashMap
BrokenDreams
Collections
这篇总结一下java.util.IdentityHashMap。从类名上可以猜到,这个类本质应该还是一个散列表,只是前面有Identity修饰,是一种特殊的HashMap。
简单的说,IdentityHashMap和HashM
- 读《研磨设计模式》-代码笔记-享元模式-Flyweight
bylijinnan
java设计模式
声明: 本文只为方便我个人查阅和理解,详细的分析以及源代码请移步 原作者的博客http://chjavach.iteye.com/
import java.util.ArrayList;
import java.util.Collection;
import java.util.HashMap;
import java.util.List;
import java
- PS人像润饰&调色教程集锦
cherishLC
PS
1、仿制图章沿轮廓润饰——柔化图像,凸显轮廓
http://www.howzhi.com/course/retouching/
新建一个透明图层,使用仿制图章不断Alt+鼠标左键选点,设置透明度为21%,大小为修饰区域的1/3左右(比如胳膊宽度的1/3),再沿纹理方向(比如胳膊方向)进行修饰。
所有修饰完成后,对该润饰图层添加噪声,噪声大小应该和
- 更新多个字段的UPDATE语句
crabdave
update
更新多个字段的UPDATE语句
update tableA a
set (a.v1, a.v2, a.v3, a.v4) = --使用括号确定更新的字段范围
- hive实例讲解实现in和not in子句
daizj
hivenot inin
本文转自:http://www.cnblogs.com/ggjucheng/archive/2013/01/03/2842855.html
当前hive不支持 in或not in 中包含查询子句的语法,所以只能通过left join实现。
假设有一个登陆表login(当天登陆记录,只有一个uid),和一个用户注册表regusers(当天注册用户,字段只有一个uid),这两个表都包含
- 一道24点的10+种非人类解法(2,3,10,10)
dsjt
算法
这是人类算24点的方法?!!!
事件缘由:今天晚上突然看到一条24点状态,当时惊为天人,这NM叫人啊?以下是那条状态
朱明西 : 24点,算2 3 10 10,我LX炮狗等面对四张牌痛不欲生,结果跑跑同学扫了一眼说,算出来了,2的10次方减10的3次方。。我草这是人类的算24点啊。。
然后么。。。我就在深夜很得瑟的问室友求室友算
刚出完题,文哥的暴走之旅开始了
5秒后
- 关于YII的菜单插件 CMenu和面包末breadcrumbs路径管理插件的一些使用问题
dcj3sjt126com
yiiframework
在使用 YIi的路径管理工具时,发现了一个问题。 <?php  
- 对象与关系之间的矛盾:“阻抗失配”效应[转]
come_for_dream
对象
概述
“阻抗失配”这一词组通常用来描述面向对象应用向传统的关系数据库(RDBMS)存放数据时所遇到的数据表述不一致问题。C++程序员已经被这个问题困扰了好多年,而现在的Java程序员和其它面向对象开发人员也对这个问题深感头痛。
“阻抗失配”产生的原因是因为对象模型与关系模型之间缺乏固有的亲合力。“阻抗失配”所带来的问题包括:类的层次关系必须绑定为关系模式(将对象
- 学习编程那点事
gcq511120594
编程互联网
一年前的夏天,我还在纠结要不要改行,要不要去学php?能学到真本事吗?改行能成功吗?太多的问题,我终于不顾一切,下定决心,辞去了工作,来到传说中的帝都。老师给的乘车方式还算有效,很顺利的就到了学校,赶巧了,正好学校搬到了新校区。先安顿了下来,过了个轻松的周末,第一次到帝都,逛逛吧!
接下来的周一,是我噩梦的开始,学习内容对我这个零基础的人来说,除了勉强完成老师布置的作业外,我已经没有时间和精力去
- Reverse Linked List II
hcx2013
list
Reverse a linked list from position m to n. Do it in-place and in one-pass.
For example:Given 1->2->3->4->5->NULL, m = 2 and n = 4,
return 
- Spring4.1新特性——页面自动化测试框架Spring MVC Test HtmlUnit简介
jinnianshilongnian
spring 4.1
目录
Spring4.1新特性——综述
Spring4.1新特性——Spring核心部分及其他
Spring4.1新特性——Spring缓存框架增强
Spring4.1新特性——异步调用和事件机制的异常处理
Spring4.1新特性——数据库集成测试脚本初始化
Spring4.1新特性——Spring MVC增强
Spring4.1新特性——页面自动化测试框架Spring MVC T
- Hadoop集群工具distcp
liyonghui160com
1. 环境描述
两个集群:rock 和 stone
rock无kerberos权限认证,stone有要求认证。
1. 从rock复制到stone,采用hdfs
Hadoop distcp -i hdfs://rock-nn:8020/user/cxz/input hdfs://stone-nn:8020/user/cxz/运行在rock端,即源端问题:报版本
- 一个备份MySQL数据库的简单Shell脚本
pda158
mysql脚本
主脚本(用于备份mysql数据库): 该Shell脚本可以自动备份
数据库。只要复制粘贴本脚本到文本编辑器中,输入数据库用户名、密码以及数据库名即可。我备份数据库使用的是mysqlump 命令。后面会对每行脚本命令进行说明。
1. 分别建立目录“backup”和“oldbackup” #mkdir /backup #mkdir /oldbackup
- 300个涵盖IT各方面的免费资源(中)——设计与编码篇
shoothao
IT资源图标库图片库色彩板字体
A. 免费的设计资源
Freebbble:来自于Dribbble的免费的高质量作品。
Dribbble:Dribbble上“免费”的搜索结果——这是巨大的宝藏。
Graphic Burger:每个像素点都做得很细的绝佳的设计资源。
Pixel Buddha:免费和优质资源的专业社区。
Premium Pixels:为那些有创意的人提供免费的素材。
- thrift总结 - 跨语言服务开发
uule
thrift
官网
官网JAVA例子
thrift入门介绍
IBM-Apache Thrift - 可伸缩的跨语言服务开发框架
Thrift入门及Java实例演示
thrift的使用介绍
RPC
POM:
<dependency>
<groupId>org.apache.thrift</groupId>