- Node.js 多模态图像描述服务 调用siliconflow:现代 JavaScript 实践
老大白菜
vue3/vue2nodejsnode.jsjavascriptubuntu
Node.js多模态图像描述服务:现代JavaScript实践项目背景本项目使用Node.js和TypeScript实现一个高性能的图像描述微服务,展示JavaScript在多模态AI应用中的强大能力。技术栈Node.jsTypeScriptExpress.jsOpenAIAPIdotenvRxJS(可选,用于响应式编程)项目初始化#创建项目目录mkdirimage-description-ser
- 标准化可观察量:Web标准新成员及其与RxJS的差异
exploration-earth
前端javascript开发语言
当前,可观察对象(乃至信号)正逐步成为Web标准体系不可或缺的一部分,这一趋势不仅预示着Web开发技术的进一步成熟与规范化,也为开发者们提供了更加统一、高效的编程接口。相较于RxJS这一流行的响应式编程库中的Observables,标准化的可观察量在设计理念与实现细节上均展现出若干显著的不同点,这些差异旨在更好地适应Web环境的特殊需求,提升开发效率与代码的可维护性。具体而言,标准化后的可观察量可
- 开发浏览器插件太难?试试 crxjs,效率飙升的秘密武器!
前端chrome
浏览器插件开发一直以来都是前端开发者的一块重要阵地。它能让我们通过扩展浏览器功能,为用户提供便捷的工具和更流畅的使用体验。然而,许多开发者在尝试插件开发时,却常常因为复杂的API、缺乏现代开发工具支持以及传统工具链无法实现热重载而望而却步。每次修改代码都需要重新打包、加载插件,甚至重启浏览器,不仅耗时,还容易打断开发思路。如果你也有类似的困扰,那么crxjs能成为你的终极解决方案。什么是crxjs
- angular 防抖和节流踩坑
海绵饱饱_wk
angularangular.jsjavascript前端
如果在angualr项目中实现防抖节流,可以使用封装好的模块,比如rxjs。但今天说的是使用原始的防抖节流方法遇到的问题:以节流为例,先贴一段常见的原始节流代码:functionthrottle(fn){ letcanRun=true;//通过闭包保存一个标记 returnfunction(){ if(!canRun)return;//在函数开头判断标记是否为true,不为true则
- Angular + rxjs 实现 某个方法防抖
clearlove_lwc
Angularangular.js前端
场景:监听输入变化从而触发搜索方法或某个方法的搜索框、输入框等//引入rxjs等包import{Subject}from'rxjs';import{distinctUntilChanged,debounceTime}from'rxjs/operators';举例:search()方法会调用getList()这个方法向后台查询数据//预置方法/*调用后台查询数据接口*/getList(){*****
- Angular中如何实现防抖和节流
crary,记忆
前端知识总结angular.jsjavascript前端angular
在Angular中实现防抖和节流的方法有多种,这篇博客主要是详细介绍两种常用的方法:使用RxJS操作符和使用Angular自带的工具。使用RxJS操作符实现防抖和节流:防抖(Debounce)://简易版import{debounceTime}from'rxjs/operators';input.valueChanges.pipe(debounceTime(300)).subscribe(valu
- npm ERR! code ETIMEDOUTnpm ERR! syscall connectnpm ERR! errno ETIMEDOUTnpm ERR! network request t
纬领网络
npmvue.jsjavascript
在安装npminstallrxjs一直出现下列问题npmERR!codeETIMEDOUTnpmERR!syscallconnectnpmERR!errnoETIMEDOUTnpmERR!networkrequesttohttps://registry.npmjs.org/rxjs/-/rxjs-7.5.6.tgzfailed,reason:connectETIMEDOUT104.16.21.35
- 使用wxt开发跨浏览器插件
一、背景在使用@crxjs/vite-plugin一段时间后,开发发了welibrary等图书馆插件,为了进一步推广插件计划支持Chrome、Edge浏览器之外的Firefox,为此耗费了不少时间用于调整配置,初步结论如下,1)Firefox对mv2版本支持更多,mv3版本有诸多限制,@crxjs/vite-plugin等工具打包后的产物可能无法运行2)虽然Firefox支持chrome全局变量,
- 为什么能用 RxJS 取代 Redux ?
rxjsredux
RxJS在现在的前端用比较少,但是RxJS作为响应式和函数式编程的集大成者,似乎被前端开发者遗忘,可能是学习难度大,可能是有更加方便的解决方案。不是因为Redux更具有性价比,而是RxJS可以打开更大的JS生态空间下面我们先回顾一下Redux是如何运作开始。一、Redux创建一个Store做了哪些事情?以上是一个简单的Redux的工作流。从reducer到视图派发更新的整个流程Redux通常在单页
- 响应式编程和RxJS介绍
oWSQo
响应式编程是一种面向数据流和变化传播的编程范式。面向变化传播的编程就是看最初的数据是否会随着后续对应变量的变化而变化。比如当变量B的数值改变后,变量C的数值也随之变动。面向数据流的编程是当监听一系列事件流并对这一系列事件流进行映射、过滤和合并等处理后,再响应整个事件流的回调的过程。例如在ReactiveX编程范式中,数据流被封装在一个叫Observable的对象实例中,通过观察者模式,对数据流进行
- Angular基础教程+Demo项目——尽可能全面一些——第一节
开发菜鸡
前端angular
第二节预告:生命周期函数、Rxjs、数据请求、路由学习过程中所写的Demo_GitHub——学习Angular——浅度学习Demo官网:https://angular.cn/(官网是最好的老师哦,追求技术的大神可以继续深入啦)Angular前言(跳过即可,自勉而已)一写博客,不例外的喜欢啰嗦一下,本人是广大java后端开发中的一员,但是因为工作需要不得不利用工作之余学习Angular前端,虽然我对
- RxSwift的使用详解
adaodao3056
RxSwift的使用详解一.RxSwift简介推荐:RxSwift官方文档中文:RxSwift官方文档的中文翻译RxSwift是Swift函数响应式编程的一个开源库,由Github的ReactiveX组织开发、维护其他语言像C#,Java和JS也有,Rx.Net、RxJava、rxjsRxSwift的目的是让数据/事件流和异步任务能够更方便的序列化处理,能够使用Swift进行响应式编程1.RxSw
- rxjs中withLatestFrom操符踩坑记录
无敌喜之郎
rxjs前端angular
官网描述:每当源Observable发出一个值时,它就会使用该值加上其他输入Observable的最新值来计算一个公式,然后发出该公式的输出。注意点:withLatestFrom中的Observable发出值不会被订阅,只会在下次源Observable发出值进行计算时采用最后发出的值例子:combineLatest([A$,B$//几个Observable]).pipe(withLatestFro
- RxJs高级教程
Yong_bcf4
Pipeable操作符从5.5版本开始我们提供了“pipeable操作符”,它们可以通过rxjs/operators来访问(注意"operators"是复数)。相比较于通过在rxjs/add/operator/*中以“打补丁”的方式来获取需要用到的操作符,这是一种更好的方式,注意:如果使用rxjs/operators而不修改构建过程的话会导致更大的包。详见下面的已知问题一节。重命名的操作符由于操作
- Tips of using RxJS
forks1990
AsyncEventEmitterOhEventEmitterisAngularextension,notRxJS,whatever!asyncEvent=newEventEmitter(true);EventEmitteracceptbooleanargument,subscriptiongetcalledinnextJavaScriptcycle,ifsynceventcausesdead-l
- 浅谈RxJS WebSocket
X01动力装甲
编程开发JavaScriptwebsocket网络协议网络
RxJSWebSocket是一个强大的库,使开发人员更容易在Web应用程序中使用WebSocket。当与Angular结合使用时,RxJSWebSocket可以帮助简化前端和后端系统之间实时连接的创建和维护。什么是WebSocket?WebSocket是一种通信协议,它允许客户端和服务器通过单个TCP连接进行双向数据交换。与遵循请求-响应模型的HTTP不同,WebSocket提供了一个持久的、低延
- Rxjs 函数式编程 响应式编程 观察者模式 推送体系 惰性
glenlg
新概念:在RxJS中用来解决异步事件管理的的基本概念是:Observable(可观察对象):表示一个概念,这个概念是一个可调用的未来值或事件的集合。Observer(观察者):一个回调函数的集合,它知道如何去监听由Observable提供的值。Subscription(订阅):表示Observable的执行,主要用于取消Observable的执行。Operators(操作符):采用函数式编程风格的
- Promise的链式调用案例讲解
球球不吃虾
javascrip基础知识前端javascript
文章目录案例分析问题解读修改建议还有什么其他方式实现这种延迟调用链的吗?1.回调函数(Callback)2.Promise链3.Promise.all和数组映射4.Generator函数和co库5.Observable(如RxJS)6.Async/Await和for...of循环这篇文章通过一个小案例,一起了解Promise的链式调用案例分析这里我模拟某个语音功能的操作流程,每隔一秒钟,我去模拟一
- vue学习(41)消息订阅与发布
哆啦C梦的百宝箱
知识点消息订阅与发布是一种理念,实现它需要具体的第三方库,比如在angular中我们常用的rxjs,在这里讲的是使用pubsub-js这个库。一种组件间通信的方式,适用于任何组件间通信。使用步骤安装pubsub:npmipubsub-js引入:importpubsubfrom'pubsub-js'订阅:A组件想接收消息,则在A中订阅消息,订阅的回调写在A组件中。...mounted(){//订阅消
- Angular系列教程之观察者模式和RxJS
偏安zzcoder
Angularangular.js观察者模式前端rxjs
文章目录引言RxJS简介RxJS中的设计模式观察者模式迭代器模式示例代码RxJS在Angular中的应用总结引言在Angular开发中,我们经常需要处理异步操作,例如从后端获取数据或与用户的交互。为了更好地管理这些异步操作,Angular中引入了RxJS(响应式编程库),它基于观察者模式提供了一种优雅的解决方案。本文将介绍RxJS的基本概念和使用方法,并附上示例代码进行说明。RxJS简介RxJS全
- Angular学习笔记(三)
langzitianya
前端Angular教程笔记
以下内容基于Angular文档中文版的学习目录Observable和RxJSObservable概览定义观察者订阅创建可观察对象多播RxJS库创建可观察对象的函数操作错误处理可观察对象的命名约定Angular中的可观察对象HTTPAsync管道路由器(router)响应式表单(reactiveforms)实际运用输入提示(type-ahead)建议指数化退避NgModule模块元数据模块类别汇总提
- [译] 认识 rxjs 中的 BehaviorSubject、ReplaySubject 以及 AsyncSubject
weixin_34265814
javascriptViewUI
原文链接:UnderstandingrxjsBehaviorSubject,ReplaySubjectandAsyncSubject原文作者:LuukGruijs;发表于2018年5月4日译者:yk;如需转载,请注明出处,谢谢合作!Subject的作用是实现Observable的多播。由于其Observableexecution是在多个订阅者之间共享的,所以它可以确保每个订阅者接收到的数据绝对相等
- RxJS 核心概念之Subject
Alex__Gong
angular2RxJSangular2+
本文出处:https://segmentfault.com/a/1190000005069851,我做了一部分修改我们在接触到RxJS的时候,不免会有点晕头转向的感觉,对于什么是Subject,什么是Observer,什么是Observable,总感觉晕乎乎的。下面我引用一篇为自认为比较通俗易懂的博文,再加上自己的描述来给大家解释下,弄明白之后对于学习Angular2+有很大的帮助,因为在angu
- RXJS中Subject, BehaviorSubject, ReplaySubject, AsyncSubject的区别?
金木讲编程
前端angular.jstypescript
在RxJS(ReactiveExtensionsforJavaScript)中,Subject、BehaviorSubject、ReplaySubject和AsyncSubject都是Observable的变体,它们用于处理观察者模式中的不同场景。以下是它们之间的主要区别:1、Subject:是一种特殊的Observable,同时也是观察者。可以通过调用next()方法向Subject中推送新的值
- 【angular教程240111】08异步数据流编程与angular :promise,Rxjs6.x
Biehmltym
angular.js前端javascript
【angular教程240111】08异步数据流编程与angular:promise,Rxjs6.x目录标题一级目录二级目录三级目录〇、编程里的异步1异步编程常见的几种方法2代码示例其中的一些方法:1.回调函数(CallbackFunctions)2.事件监听/发布订阅(EventListeners/Pub-Sub)3.Promise4.RxJS一、Rxjs介绍1使用RxJS的处理HTTP异步请求
- RxJS的另外四种实现方式(一)——代码最小的库
一个灰
接上篇RxJS的另外四种实现方式(序)起因想到这个库的原因,是看了callbag库想到的,callbag库的原理大家可以自己找资料了解,我就不多赘述,我只谈谈我的理解。callbag的设计思路是把消费者和生产者合并成一个,通过互相传递一个回调函数实现通讯。看过部分操作符实现原理的同学肯定觉得逻辑十分难解,因为过多的回调使得你的脑回路不够用了。我用了一些库函数后,我意识到,其实不需要如此复杂的设计,
- 决定开始公开写作
liethes
读这篇文章《流动的数据——使用RxJS构造复杂单页应用的数据逻辑》时,感觉:把工作中的感想整理出来,对更深层次地掌握知识,非常有好处。遂决定开写。是为一。
- RxJS的另外四种实现方式(后记)—— 同时实现管道和链式编程
一个灰
目录RxJS的另外四种实现方式(序)RxJS的另外四种实现方式(一)——代码最小的库RxJS的另外四种实现方式(二)——代码最小的库(续)RxJS的另外四种实现方式(三)——性能最高的库RxJS的另外四种实现方式(四)——性能最高的库(续)RxJS的另外四种实现方式(五)——使用生成器实现RxJS的另外四种实现方式(六)——使用Stream类实现github地址https://github.com
- RxJS 操作符-学习笔记
吴杼恩
学习笔记前端
提前准备:pipe方法:用于组合多个操作符,可以将一系列操作符作为参数传递给pipe方法,这些操作符将依次对数据流进行处理。这里的依次很关键,也代表着pipe()中组合的这么几个操作符的执行顺序就是从开始一直到结束的,其中的数据会同流水线一般在各个操作符中进行传递。上一个操作符把数据处理好了,会自动地把这个处理好的数据送给下一个操作符接收,基于这个在上一步处理过的数据再进行进一步的加工,如此往复,
- RxJS之fromEvent学习
crary,记忆
学习前端angular.jsangularjavascript
有情提示:阅读此博客前,可先阅读博客https://blog.csdn.net/qq_44327851/article/details/135251408对RxJS进行简单的了解。概念:fromEvent是RxJS中的一个操作符,用于将事件转换为可观察的对象。它的作用是创建一个可观察对象,该对象会监听指定事件源上特定类型的事件,并在事件发生时发出相应的数据。在RxJS中,事件源可以是DOM元素、N
- Algorithm
香水浓
javaAlgorithm
冒泡排序
public static void sort(Integer[] param) {
for (int i = param.length - 1; i > 0; i--) {
for (int j = 0; j < i; j++) {
int current = param[j];
int next = param[j + 1];
- mongoDB 复杂查询表达式
开窍的石头
mongodb
1:count
Pg: db.user.find().count();
统计多少条数据
2:不等于$ne
Pg: db.user.find({_id:{$ne:3}},{name:1,sex:1,_id:0});
查询id不等于3的数据。
3:大于$gt $gte(大于等于)
&n
- Jboss Java heap space异常解决方法, jboss OutOfMemoryError : PermGen space
0624chenhong
jvmjboss
转自
http://blog.csdn.net/zou274/article/details/5552630
解决办法:
window->preferences->java->installed jres->edit jre
把default vm arguments 的参数设为-Xms64m -Xmx512m
----------------
- 文件上传 下载 解析 相对路径
不懂事的小屁孩
文件上传
有点坑吧,弄这么一个简单的东西弄了一天多,身边还有大神指导着,网上各种百度着。
下面总结一下遇到的问题:
文件上传,在页面上传的时候,不要想着去操作绝对路径,浏览器会对客户端的信息进行保护,避免用户信息收到攻击。
在上传图片,或者文件时,使用form表单来操作。
前台通过form表单传输一个流到后台,而不是ajax传递参数到后台,代码如下:
<form action=&
- 怎么实现qq空间批量点赞
换个号韩国红果果
qq
纯粹为了好玩!!
逻辑很简单
1 打开浏览器console;输入以下代码。
先上添加赞的代码
var tools={};
//添加所有赞
function init(){
document.body.scrollTop=10000;
setTimeout(function(){document.body.scrollTop=0;},2000);//加
- 判断是否为中文
灵静志远
中文
方法一:
public class Zhidao {
public static void main(String args[]) {
String s = "sdf灭礌 kjl d{';\fdsjlk是";
int n=0;
for(int i=0; i<s.length(); i++) {
n = (int)s.charAt(i);
if((
- 一个电话面试后总结
a-john
面试
今天,接了一个电话面试,对于还是初学者的我来说,紧张了半天。
面试的问题分了层次,对于一类问题,由简到难。自己觉得回答不好的地方作了一下总结:
在谈到集合类的时候,举几个常用的集合类,想都没想,直接说了list,map。
然后对list和map分别举几个类型:
list方面:ArrayList,LinkedList。在谈到他们的区别时,愣住了
- MSSQL中Escape转义的使用
aijuans
MSSQL
IF OBJECT_ID('tempdb..#ABC') is not null
drop table tempdb..#ABC
create table #ABC
(
PATHNAME NVARCHAR(50)
)
insert into #ABC
SELECT N'/ABCDEFGHI'
UNION ALL SELECT N'/ABCDGAFGASASSDFA'
UNION ALL
- 一个简单的存储过程
asialee
mysql存储过程构造数据批量插入
今天要批量的生成一批测试数据,其中中间有部分数据是变化的,本来想写个程序来生成的,后来想到存储过程就可以搞定,所以随手写了一个,记录在此:
DELIMITER $$
DROP PROCEDURE IF EXISTS inse
- annot convert from HomeFragment_1 to Fragment
百合不是茶
android导包错误
创建了几个类继承Fragment, 需要将创建的类存储在ArrayList<Fragment>中; 出现不能将new 出来的对象放到队列中,原因很简单;
创建类时引入包是:import android.app.Fragment;
创建队列和对象时使用的包是:import android.support.v4.ap
- Weblogic10两种修改端口的方法
bijian1013
weblogic端口号配置管理config.xml
一.进入控制台进行修改 1.进入控制台: http://127.0.0.1:7001/console 2.展开左边树菜单 域结构->环境->服务器-->点击AdminServer(管理) &
- mysql 操作指令
征客丶
mysql
一、连接mysql
进入 mysql 的安装目录;
$ bin/mysql -p [host IP 如果是登录本地的mysql 可以不写 -p 直接 -u] -u [userName] -p
输入密码,回车,接连;
二、权限操作[如果你很了解mysql数据库后,你可以直接去修改系统表,然后用 mysql> flush privileges; 指令让权限生效]
1、赋权
mys
- 【Hive一】Hive入门
bit1129
hive
Hive安装与配置
Hive的运行需要依赖于Hadoop,因此需要首先安装Hadoop2.5.2,并且Hive的启动前需要首先启动Hadoop。
Hive安装和配置的步骤
1. 从如下地址下载Hive0.14.0
http://mirror.bit.edu.cn/apache/hive/
2.解压hive,在系统变
- ajax 三种提交请求的方法
BlueSkator
Ajaxjqery
1、ajax 提交请求
$.ajax({
type:"post",
url : "${ctx}/front/Hotel/getAllHotelByAjax.do",
dataType : "json",
success : function(result) {
try {
for(v
- mongodb开发环境下的搭建入门
braveCS
运维
linux下安装mongodb
1)官网下载mongodb-linux-x86_64-rhel62-3.0.4.gz
2)linux 解压
gzip -d mongodb-linux-x86_64-rhel62-3.0.4.gz;
mv mongodb-linux-x86_64-rhel62-3.0.4 mongodb-linux-x86_64-rhel62-
- 编程之美-最短摘要的生成
bylijinnan
java数据结构算法编程之美
import java.util.HashMap;
import java.util.Map;
import java.util.Map.Entry;
public class ShortestAbstract {
/**
* 编程之美 最短摘要的生成
* 扫描过程始终保持一个[pBegin,pEnd]的range,初始化确保[pBegin,pEnd]的ran
- json数据解析及typeof
chengxuyuancsdn
jstypeofjson解析
// json格式
var people='{"authors": [{"firstName": "AAA","lastName": "BBB"},'
+' {"firstName": "CCC&
- 流程系统设计的层次和目标
comsci
设计模式数据结构sql框架脚本
流程系统设计的层次和目标
 
- RMAN List和report 命令
daizj
oraclelistreportrman
LIST 命令
使用RMAN LIST 命令显示有关资料档案库中记录的备份集、代理副本和映像副本的
信息。使用此命令可列出:
• RMAN 资料档案库中状态不是AVAILABLE 的备份和副本
• 可用的且可以用于还原操作的数据文件备份和副本
• 备份集和副本,其中包含指定数据文件列表或指定表空间的备份
• 包含指定名称或范围的所有归档日志备份的备份集和副本
• 由标记、完成时间、可
- 二叉树:红黑树
dieslrae
二叉树
红黑树是一种自平衡的二叉树,它的查找,插入,删除操作时间复杂度皆为O(logN),不会出现普通二叉搜索树在最差情况时时间复杂度会变为O(N)的问题.
红黑树必须遵循红黑规则,规则如下
1、每个节点不是红就是黑。 2、根总是黑的 &
- C语言homework3,7个小题目的代码
dcj3sjt126com
c
1、打印100以内的所有奇数。
# include <stdio.h>
int main(void)
{
int i;
for (i=1; i<=100; i++)
{
if (i%2 != 0)
printf("%d ", i);
}
return 0;
}
2、从键盘上输入10个整数,
- 自定义按钮, 图片在上, 文字在下, 居中显示
dcj3sjt126com
自定义
#import <UIKit/UIKit.h>
@interface MyButton : UIButton
-(void)setFrame:(CGRect)frame ImageName:(NSString*)imageName Target:(id)target Action:(SEL)action Title:(NSString*)title Font:(CGFloa
- MySQL查询语句练习题,测试足够用了
flyvszhb
sqlmysql
http://blog.sina.com.cn/s/blog_767d65530101861c.html
1.创建student和score表
CREATE TABLE student (
id INT(10) NOT NULL UNIQUE PRIMARY KEY ,
name VARCHAR
- 转:MyBatis Generator 详解
happyqing
mybatis
MyBatis Generator 详解
http://blog.csdn.net/isea533/article/details/42102297
MyBatis Generator详解
http://git.oschina.net/free/Mybatis_Utils/blob/master/MybatisGeneator/MybatisGeneator.
- 让程序员少走弯路的14个忠告
jingjing0907
工作计划学习
无论是谁,在刚进入某个领域之时,有再大的雄心壮志也敌不过眼前的迷茫:不知道应该怎么做,不知道应该做什么。下面是一名软件开发人员所学到的经验,希望能对大家有所帮助
1.不要害怕在工作中学习。
只要有电脑,就可以通过电子阅读器阅读报纸和大多数书籍。如果你只是做好自己的本职工作以及分配的任务,那是学不到很多东西的。如果你盲目地要求更多的工作,也是不可能提升自己的。放
- nginx和NetScaler区别
流浪鱼
nginx
NetScaler是一个完整的包含操作系统和应用交付功能的产品,Nginx并不包含操作系统,在处理连接方面,需要依赖于操作系统,所以在并发连接数方面和防DoS攻击方面,Nginx不具备优势。
2.易用性方面差别也比较大。Nginx对管理员的水平要求比较高,参数比较多,不确定性给运营带来隐患。在NetScaler常见的配置如健康检查,HA等,在Nginx上的配置的实现相对复杂。
3.策略灵活度方
- 第11章 动画效果(下)
onestopweb
动画
index.html
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/
- FAQ - SAP BW BO roadmap
blueoxygen
BOBW
http://www.sdn.sap.com/irj/boc/business-objects-for-sap-faq
Besides, I care that how to integrate tightly.
By the way, for BW consultants, please just focus on Query Designer which i
- 关于java堆内存溢出的几种情况
tomcat_oracle
javajvmjdkthread
【情况一】:
java.lang.OutOfMemoryError: Java heap space:这种是java堆内存不够,一个原因是真不够,另一个原因是程序中有死循环; 如果是java堆内存不够的话,可以通过调整JVM下面的配置来解决: <jvm-arg>-Xms3062m</jvm-arg> <jvm-arg>-Xmx
- Manifest.permission_group权限组
阿尔萨斯
Permission
结构
继承关系
public static final class Manifest.permission_group extends Object
java.lang.Object
android. Manifest.permission_group 常量
ACCOUNTS 直接通过统计管理器访问管理的统计
COST_MONEY可以用来让用户花钱但不需要通过与他们直接牵涉的权限
D