摘要:
今天在调整一生成java代码的工具时,要用到在不同语言间互转数据类型的逻辑,原来的代码中根据excel记录的行号来计算,再到另外一个collection中获取,个人想着这也太土鳖了,于是搜了下,在vba中,没有map的概念,也没有原生的dictionary类型,是通过CreateObject("Sc
阅读全文
posted @ 2017-02-22 12:31
zhjh256
阅读(2289)
推荐(0)
摘要:
有时候,由于各方面原因比如安全原因、系统间隔离,我们需要实现在多个rabbitmq实例或者一个rabbitmq实例的多个vhost间推送消息。在上一版的实现中,公司使用java自行实现了一个类似转发器的功能,其结构为: 内部MQ->java-pusher->外部MQ 其中在java-pusher的配
阅读全文
posted @ 2017-02-20 11:10
zhjh256
阅读(1315)
推荐(0)
摘要:
注:linux下除了gcc和clang外,其他常用的编译器还包括intel c++编译器,ibm xlc编译器,sunpro编译器。 完整的gcc详解可以参见https://www.cnblogs.com/zhjh256/p/15596130.html。 “-Wall”选项打开所有最常用到的编译警告
阅读全文
posted @ 2017-02-19 21:45
zhjh256
阅读(10389)
推荐(0)
摘要:
因为项目原因,需要使用到rabbitmq的c客户端库。首先,参见上一篇windows下openssl编译,如果已经使用cmake编译过了,则先delete cache(File-Delete Cache),否则原来的cmake缓存都在了,将仍然会出现原来的错误。 依次点击configire、gene
阅读全文
posted @ 2017-02-19 17:23
zhjh256
阅读(994)
推荐(0)
摘要:
昨晚,在编译rabbitmq-c时,使用cmake生成vs项目文件时遇到下列错误: CMake Error at C:/Program Files/CMake/share/cmake-3.6/Modules/FindPackageHandleStandardArgs.cmake:148 (messa
阅读全文
posted @ 2017-02-19 16:05
zhjh256
阅读(8610)
推荐(0)
摘要:
actor model是1973年就提出的一个分布式并发编程模型,在erlang语言中得到广泛支持和应用。目前Java中也出现了很多支持actor模型的库:akka、killim、jetlang等等,其中akka是使用Scala写的,有scala和java两套使用接口;killim需要对编译出来的c
阅读全文
posted @ 2017-02-17 13:05
zhjh256
阅读(438)
推荐(0)
摘要:
今天,将一个环境切换成行情优化后的版本后,发现io等待还是挺高,这还是第一次出现的。其他很多套环境都没有这个问题了,故iotop看了下,基本可以确定为是mysql进程的问题,如下: 但是iotop只能看到进程级别,对于rdbms而言,通常力度并不够,此时需要进一步使用其他工具比如io-profile
阅读全文
posted @ 2017-02-17 11:04
zhjh256
阅读(542)
推荐(0)
摘要:
刚在尝试重现一个bug时,好像在killed mysql一段时间之后,io一直很高,如下: iotop了一下,jbd2进程占用大量IO处理,搜索了下,关于jbd2,jbd2是ext4文件系统的一部分。ext4文件系统出现过此bug,bug原理大致是,文件的写和请求会导致其中一个int型的值不断增大,
阅读全文
posted @ 2017-02-13 16:20
zhjh256
阅读(1001)
推荐(0)
摘要:
不同于在java中,虽然在java中,有些第三方库只是做了桥接的功能,比如slf4j-log4j-api,但是在运行时他们仍然是需要的,所以最多只能说是松耦合做得很好。 但是在c++中,一般我们应用第三方库的时候,是头文件+库(lib/a或so/dll)配对的形式(常用必备的c/c++三方库 htt
阅读全文
posted @ 2017-02-12 12:49
zhjh256
阅读(2564)
推荐(0)
摘要:
看jstack输出的时候,可以发现很多状态都是TIMED_WAITING(parking),如下所示: "http-bio-8080-exec-16" #70 daemon prio=5 os_prio=0 tid=0x00007f6088027800 nid=0x3a1f waiting on c
阅读全文
posted @ 2017-02-11 17:52
zhjh256
阅读(1606)
推荐(0)
摘要:
最近在看pthread方面的书,看到条件变量一节的时候,回忆了下java中条件变量的使用方式。 java中条件变量都实现了java.util.concurrent.locks.Condition接口,条件变量的实例化是通过一个Lock对象上调用newCondition()方法来获取的,这样,条件就和
阅读全文
posted @ 2017-02-11 17:16
zhjh256
阅读(15283)
推荐(1)
摘要:
晚上花几分钟在windows下测了下pthread的用法,出现错误 1 error LNK2019: 无法解析的外部符号 __imp__pthread_create,该符号在函数 _main 中被引用 经网上搜,反正都没解决,其中一个说引入#pragma comment(lib, "pthreadV
阅读全文
posted @ 2017-02-09 21:17
zhjh256
阅读(5817)
推荐(0)
摘要:
最近面试,提到几个之前没有遇到过的问题(不同的人不同的风格): Q1:如何应对雪崩; http://www.2cto.com/os/201508/433330.html http://www.cnblogs.com/chengJAVA/p/5785850.html 我们自己的中间件实现上采取了客户端
阅读全文
posted @ 2017-02-08 21:20
zhjh256
阅读(266)
推荐(0)
摘要:
性能上从低到高如下: OioSocketChannel:传统,阻塞式编程。 NioSocketChannel:select/poll或者epoll,jdk 7之后linux下会自动选择epoll。epoll原理及与select/poll的伸缩性性能测试基准 EpollSocketChannel:ep
阅读全文
posted @ 2017-02-07 12:43
zhjh256
阅读(1924)
推荐(0)
摘要:
最近一券商那边扫描反馈了下面几个非业务型安全漏洞,要求解决,如下: XSS 自己写个脚本response的时候对特殊字符进行了处理,或者使用OWASP提供的官方包antisamy,https://blog.csdn.net/ru_li/article/details/51334082。 HTML f
阅读全文
posted @ 2017-02-07 10:51
zhjh256
阅读(1414)
推荐(0)
摘要:
log4j.logger.io.netty=INFO, stdout, spiderlog4j.logger.com.ld.net.spider=INFO, stdout, spider log4j.appender.spider=org.apache.log4j.RollingFileAppend
阅读全文
posted @ 2017-02-07 10:20
zhjh256
阅读(214)
推荐(0)
摘要:
介绍 总的来说,rabbitmq使用erlang(Elixir,排名50-60)是erlang的友好版,编译成erlang执行码)语言编写,其架构类似于servlet容器运行servlet应用,底层是erlang VM、然后是erlang节点,上面是应用。如下所示: 每个MQ中运行的应用可通过rab
阅读全文
posted @ 2017-02-05 18:20
zhjh256
阅读(1133)
推荐(0)
摘要:
同上一篇一样,在jmap -histo中发现MpscChunkedArrayQueue类的实例比较多,javadoc看了下,其原来是出自JC Tools,https://github.com/JCTools/JCTools。 通过官网,我们可以看到,它针对实际的场景对JDK自带的并发队列做了一些特定
阅读全文
posted @ 2017-02-05 17:41
zhjh256
阅读(1728)
推荐(0)
摘要:
最近在分析一潜在内存泄露问题的时候,jmap出来中有很多的FastThreadLocalThread实例,看了下javadoc,如下: A special variant of ThreadLocal that yields higher access performance when access
阅读全文
posted @ 2017-02-05 16:20
zhjh256
阅读(1465)
推荐(0)
摘要:
初学cpp,因为之前装linux下各种软件的时候,知道LD_LIBRARY_PATH可以指定动态库的目录。今天在vc集成log4cpp的时候,编译main时报error LNK2019: 无法解析的外部符号,已经在 包含了目标dll的目录,经搜索帖子http://bbs.csdn.net/topic
阅读全文
posted @ 2017-02-04 13:48
zhjh256
阅读(11779)
推荐(0)
摘要:
对于sqlite,实际中从来没有用过,也几乎没有考虑过其使用场景,更不要说专门去研究它了,今天看最新的数据库流行度排行榜的时候,发现sqlite的长期趋势好像一直在第十位左右徘徊,特地搜索了下其使用场景,下面的应该是比较客观的: 准确地说,SQLite并不应该用来直接和MySQL、Oracle、Po
阅读全文
posted @ 2017-02-04 13:39
zhjh256
阅读(425)
推荐(0)
摘要:
在有几个应用中,在启动的时候发现下列警告: The version of the script (3.5.29) doesn't match the version of this Wrapper (3.5.27). This might cause some problems--> Wrapper
阅读全文
posted @ 2017-02-04 11:36
zhjh256
阅读(730)
推荐(0)
摘要:
早上,有个应用又挂了,客户端打开时报404,看进程是还在的。倒回第一次异常的地方,可见catalina.out中有如下信息: 08:46:56.646 [ContainerBackgroundProcessor[StandardEngine[Catalina]]] DEBUG o.s.b.f.s.D
阅读全文
posted @ 2017-02-04 10:50
zhjh256
阅读(1604)
推荐(0)
摘要:
一般在容器比如tomcat/weblogic中运行时,我们都是通过log4j控制日志输出的,因为我们现在很多服务端使用java service wrapper(至于为什么使用jsw,原先是比较排斥使用的,但是当一台服务器上部署10来个应用时,我们无条件的选择了jsw,因为不需要折腾和规划这么多的端口
阅读全文
posted @ 2017-02-04 10:16
zhjh256
阅读(1135)
推荐(0)
摘要:
晚上,在测试tinyxml的时候,发现其中声明了<?xml version="1.0" standalone="no" ?>,经查,其含义为standalone表示该xml是不是独立的,如果是yes,则表示这个XML文档时独立的,不能引用外部的DTD规范文件;如果是no,则该XML文档不是独立的,表
阅读全文
posted @ 2017-02-03 21:04
zhjh256
阅读(1365)
推荐(1)
摘要:
如同linux下通常要求安装特定版本的libstdc++一样,windows下vc++生成的exe发布时的依赖dll问题,可以参见帖子,http://bbs.csdn.net/topics/391052257,这个帖子应该来说已经很清晰的说明了如何分发的问题。 需要注意的是生成的dll/lib是32
阅读全文
posted @ 2017-02-03 19:41
zhjh256
阅读(483)
推荐(0)
摘要:
今天早上,java应用中发现too many open files,检查了下使用的连接数发现基本上在两三百左右,mysql打开的文件数也就几百左右,再看所有tcp连接,发现3306的连接有4000多,且状态为time_wait,time_wait发生在tcp连接关闭的阶段如下所示: 到11:30分收
阅读全文
posted @ 2017-02-03 19:18
zhjh256
阅读(722)
推荐(0)
摘要:
log4cpp,http://log4cpp.sourceforge.net/,跟log4j一样,不说最重要,绝对是最常用的。 zk 客户端,https://blog.csdn.net/yangzhen92/article/details/53248294 memcached,libmemcache
阅读全文
posted @ 2017-02-03 19:02
zhjh256
阅读(196)
推荐(0)
摘要:
早上一运维同事说,一个报盘程序启动的时候报了"ESOURCE_LOCKED - cannot obtain exclusive access to locked queue '2484_0_00163'",因为之前一直不管报盘的事情,后面仔细看了下,这个错误应该不是开发自己加上的,搜了下,是两个不同
阅读全文
posted @ 2017-02-03 09:15
zhjh256
阅读(346)
推荐(0)
摘要:
春节放假期间,一直在学习c++,越想越发现c++标准之于gcc/vc/boost等实现相当于jsr规范之于sunjdk/ibmjdk/tomcat/weblogic等实现
阅读全文
posted @ 2017-02-03 08:00
zhjh256
阅读(152)
推荐(0)
摘要:
const_cast 用于去掉const属性,把const类型的指针变为非const类型的指针,如:const int *fun(int x,int y){} int *ptr=const_cast<int *>(fun(2.3)) dynamic_cast 该操作符用于运行时检查该转换是否类型安全
阅读全文
posted @ 2017-02-03 07:28
zhjh256
阅读(173)
推荐(0)
摘要:
在java中,我们知道除了public和private,protected外,还有默认的包可见性访问级别,虽然如此,很多时候出于早期设计缺陷的原因,我们需要访问一些包或者protected可见性级别的方法,这个时候就比较麻烦了,要是选择和目标服务在相同包中,总看起来很奇怪,如果作为子类继承,则更加奇
阅读全文
posted @ 2017-02-02 21:39
zhjh256
阅读(335)
推荐(0)
摘要:
久而久之,发现c/c++的typedef给类型自定义别名的语法糖就保证设计的一致性而言,确实是个相当不错的特性,跟oracle pl/sql的rowtype或type一样,可惜java、mysql均不支持。
阅读全文
posted @ 2017-02-02 20:10
zhjh256
阅读(196)
推荐(0)
摘要:
或许是基于一直以来c/c++头文件声明和cXX实现物理上置于独立文件的考虑,c++中的OO在现实中基本上也是按照声明和实现分离的方式进行管理和编译,如下所示: Base.h Base.cpp 分发给客户的时候,我们只要提供Base.h和Base.cpp编译后的so或者a即可。如下: 相较于于java
阅读全文
posted @ 2017-02-02 19:16
zhjh256
阅读(254)
推荐(0)
摘要:
c标准中包含了一个sleep用以实现当前线程暂停执行n毫秒,如下所示: 函数名: sleep 功 能: 执行挂起一段时间 用 法: unsigned sleep(unsigned seconds); 在VC中需要带上头文件 include <Windows.h> //没有<unistd.h> Sle
阅读全文
posted @ 2017-02-02 19:03
zhjh256
阅读(969)
推荐(0)
摘要:
默认情况下,如果没有明确声明某些函数比如赋值、拷贝函数,c++会自动生成这些函数,通常他们是对成员进行by-value拷贝。如下: 有些时候,赋值、拷贝对象并无什么意义或者不合理,比如对于socket或者thread而言,这种情况下,可以明确通过指定=delete告知编译器不要自动生成它们。如下所示
阅读全文
posted @ 2017-02-02 18:40
zhjh256
阅读(200)
推荐(0)
摘要:
对于面向对象而言,多态是最有用的基本特性之一,相对于函数指针,易用得多。下面看下c++继承和多态行为的基本特性,最后说明下和java的基本差别。 首先定义父类和子类。 base.h base.cpp Derived.h Derived.cpp 基本使用: 输出如下: 从上面的代码和结果可以看出,c+
阅读全文
posted @ 2017-01-26 13:59
zhjh256
阅读(233)
推荐(0)
摘要:
从c++ 11开始,语言核心和标准库开始引入了对多线程的原生支持。 如下所示: int doSth(char c) { default_random_engine dre(c); uniform_int_distribution<int> id(10,10000); for(int i=0;i<10
阅读全文
posted @ 2017-01-26 10:21
zhjh256
阅读(1174)
推荐(1)
摘要:
首先要来说一说字符集和编码的关系,这两者既有交叉、又有异同。https://www.runoob.com/w3cnote/charset-encoding.html、https://blog.csdn.net/weixin_44198965/article/details/93125017。简单可以
阅读全文
posted @ 2017-01-26 09:13
zhjh256
阅读(548)
推荐(0)
摘要:
c++生成随机整数和浮点数如下: 输出如下: 还可以使用标准C的rand,如下: 输出如下: 关于使用随机数引擎还是rand()函数的问题,在C++标准库第二版17.1.1看到如下说明:
阅读全文
posted @ 2017-01-26 09:10
zhjh256
阅读(794)
推荐(0)