- [TcpConnection]
Bin努力加餐饭
muduo服务器网络
`TcpConnection`类是muduo最核心的类,这个类主要封装了一个已建立的TCP连接,以及控制该TCP连接的方法(连接建立和关闭和销毁),以及该连接发生的各种事件(读/写/错误/连接)对应的处理函数,以及这个TCP连接的服务端和客户端的套接字地址信息等。成员变量private:EventLoop*loop_;//这里绝对不是Mainloop,因为tcpconnection都是在sublo
- 仿RabbitMq实现简易消息队列基础篇(Muduo库的使用)
疏 石 兰 兮
rabbitmqc++开发语言异步操作linuxubuntu
@TOCMuduo库简介Muduo由陈硕⼤佬开发,是⼀个基于⾮阻塞IO和事件驱动的C++⾼并发TCP⽹络编程库。他是一款基于主从Reactor模型的网络库,其使用的线程模型是oneloopperthread,所谓oneloopperthread指的是:一个线程只能有一个事件循环(EventLoop),用于相应计时器和IO时间一个文件描述符只能由一个线程进行读写,换句话说就是一个TCP连接必须归属某
- 【仿muduo库实现并发服务器】Connection模块
tew_gogogo
项目服务器网络android
仿muduo库实现并发服务器一.Connection模块二.成员变量1.连接唯一ID(连接管理)2.Socket对象(套接字操作管理)3.Channel对象(连接事件管理)4.Buffer对象(缓冲区管理)5.ConnStatus对象(连接状态管理)6.EventLoop对象(连接监控/定时任务管理)7.Any对象(上下文管理)8.是否启动非活跃超时连接销毁标志位9.5个阶段性回调函数三.成员函数
- 【仿muduo库实现并发服务器】LoopThreadPool模块
仿muduo库实现并发服务器1.LoopThread模块1.1成员变量1.2构造函数13线程入口函数1.4获取eventloop对象GetLoop()2.LoopThreadPool模块2.1成员变量2.2构造函数2.3配置线程数量2.4按照配置数量创建线程2.5依次分配Eventloop对象1.LoopThread模块这个模块是为了将EventLoop与线程整合起来。一个EventLoop对应一
- Muduo 定时器
小白书舍
c++网络
TimeQueue定时器图片转载自:muduo网络库源码解析(4):TimerQueue定时机制_李兆龙的技术博客_51CTO博客添加新的定时器TimerIdTimerQueue::addTimer(TimerCallbackcb,//用户自定义回调Timestampwhen,//定时器的超时时刻doubleinterval)//重复触发间隔,小于0则不重复触发{Timer*timer=newTi
- 优秀开源库muduo阅读笔记
VictorLeo
网路编程服务端编程muduo
muduo阅读笔记目录设计经验和思想服务端编程设计std::bind和std::function(基于closure闭包的编程)参考资料muduo开源库的笔记,比较杂,没有详细整理,现在就这么杂乱放着,等真的需要再好好整理。设计经验和思想对象构造做到线程安全,唯一的要求就是不要暴露this指针.即不要在构造函数中注册任何回调;也不要在构造函数中把this传给跨线程的对象;即便在构造函数的最后一行也
- muduo
2301_80355452
php前端开发语言
好的,我们来深入剖析陈硕老师开发的著名C++网络库——muduo。它以“简单、高效、易用”著称,是学习LinuxC++高性能网络编程的绝佳范本。我会尽量详细、通俗地讲解其核心思想、关键组件、源码结构和工作原理。核心思想:Reactor模式(Non-blocking+I/OMultiplexing)muduo的灵魂是Reactor模式。理解它就理解了muduo的一半。想象一下:传统阻塞模型的问题:想
- 集群聊天服务器---muduo库使用(2)
power 雀儿
集群聊天服务器学习服务器java前端
书接上回聊天服务器,这个类主要是用于处理网络连接和消息。public:ChatServer(EventLoop*loop,//事件循环constInetAddress&listenAddr,//IP+Portconststring&nameArg)//服务器的名字:_server(loop,listenAddr,nameArg),_loop(loop){//给服务器注册用户连接的创建和断开回调_s
- 【Muduo】三大核心之Channel
打完代码打篮球
Muduo网络库c++stl
Muduo网络库的Channel模块是一个关键组件,它封装了文件描述符(fd)及其相关的事件,使得在TCP网络编程中能够利用IO多路复用技术(如epoll/poll)来监听和处理这些文件描述符上的事件。封装内容文件描述符(fd):每个Channel对象都对应一个特定的文件描述符,该文件描述符通常代表一个网络连接。感兴趣的事件(events):Channel对象封装了与文件描述符相关的一组感兴趣的事
- [muduo] TcpConnection | 回调交互
lvy-
#muduosourcecode交互c++
第六章:TcpConnection在前几章中,我们已经构建了Muduo网络库的基础。我们理解EventLoop(第一章:EventLoop)是单线程的事件引擎,负责管理事件。我们学习了muduo::Thread(第二章:Thread)如何帮助在专用线程中运行EventLoop以实现并发。我们看到了Channel(第三章:Channel)如何将特定的文件描述符(如套接字)连接到EventLoop并保
- 【EventLoop】
在muduo库里边有两种线程:一种里边的事件循环专门处理新用户连接(`mainLoop`(也就是`baseLoop`)),一种里边的事件循环专门处理对应连接的所有读写事件(`ioLoop`)。EventLoop起到一个驱动循环的功能,Poller负责从事件监听器上获取监听结果,Channel类将fd及其相关属性封装,并将fd及其感兴趣事件和发生的事件以及不同事件对应的回调函数封装在一起,这样在各个
- 手写muduo网络库(十):TcpServer
achene_ql
linux网络编程与服务器开发网络开发语言c++linux服务器
引言TcpServer类在muduo网络库中扮演着对外提供服务的重要角色,它封装了TCP服务器的基本功能,包括监听连接、处理新连接、管理连接生命周期等。本文将详细剖析TcpServer类的代码实现,深入探讨其功能和实现逻辑,并结合C++语言特性进行讲解。代码文件概述TcpServer.h头文件分析#pragmaonce#include"EventLoop.h"#include"Acceptor.h
- 手写muduo网络库(终):从实际案例出发详解muduo各模块间调用关系
一、引言在之前的系列文章中,我们已经详细探讨了手写muduo网络库各个模块的实现细节。然而,仅仅了解模块的实现逻辑是不够的,还需要深入理解各个模块之间的调用关系。本文将以一个回声服务器的代码编写为例,详细剖析muduo网络库各模块间的调用关系。通过模拟代码执行过程,深入探究连接建立、事件处理、回调函数设置与调用等关键环节,为读者揭示muduo底层原理。二、程序启动与初始化#include#incl
- 手写muduo网络库(八):Buffer
achene_ql
linux网络编程与服务器开发网络开发语言linux服务器c++
一、引言在网络编程中,数据的读写是非常常见的操作。由于网络数据的收发往往是异步的,而且数据的大小和到达时间都是不确定的,因此需要一个缓冲区来暂存这些数据。Buffer类就是为了解决这个问题而设计的,它提供了一个灵活的缓冲区管理机制,能够方便地处理数据的读写操作。在muduo网络库中,Buffer类扮演着重要的角色,下面我们将详细讲解其功能和实现细节。二、Buffer类的整体功能概述Buffer类主
- 手写muduo网络库(七):深入剖析 Acceptor 类
achene_ql
linux网络编程与服务器开发网络服务器linuxc++开发语言
引言在网络编程中,服务器端程序需要能够监听客户端的连接请求并进行处理。Acceptor类在这个过程中扮演着至关重要的角色,它负责创建监听套接字、绑定地址、开始监听以及处理新的连接请求。在本文中,我们将详细剖析手写muduo网络库中的Acceptor类,探讨其实现原理和工作流程。整体功能概述Acceptor类的主要功能是在指定的地址和端口上监听客户端的连接请求,并在有新的连接到来时调用相应的回调函数
- 手写muduo网络库(四):实现线程 ID 管理与事件循环并分析EventLoop,Poller,Channel关系
achene_ql
linux网络编程与服务器开发网络服务器linuxc++开发语言后端
引言事件驱动架构中的Channel、Poller与EventLoop像是相互咬合的齿轮,它们共同构建了从底层I/O事件监听、事件分发到高层逻辑处理的完整链路。本文将深入剖析事件循环和这三个组件的交互机制,揭示muduo背后的设计思想。一、CurrentThread:高效线程ID获取机制在多线程编程,往往存在一种需求需要某个函数执行在特定线程中,要实现这个功能离不开获取当前线程的唯一标识。muduo
- muduo库EventLoop模块详解
君鼎
C++网络编程开发语言c++网络linux
muduo库EventLoop模块深度解析EventLoop是muduo网络库实现Reactor模型的核心调度中枢,负责驱动整个事件循环机制,协调Poller、Channel、TimerQueue等组件的工作。其设计遵循"OneLoopPerThread"原则。一、核心职责与设计思想1.核心职责事件循环驱动:运行事件循环(loop),持续监听和分发I/O事件任务队列管理:处理跨线程投递的异步任务定
- muduo源码解析
ZI&Yue
网络c++
1.对类进行禁止拷贝classnoncopyable{public:noncopyable(constnoncopyable&)=delete;voidoperator=(constnoncopyable&)=delete;protected:noncopyable()=default;~noncopyable()=default;};2.日志使用枚举定义日志等级enumLogLevel{TRAC
- 【JsonCpp、Muduo、C++11】JsonCpp库、Muduo库、C++11异步操作
LuckyRich1
第三方库c++开发语言
JsonCpp库、Muduo库、C++11异步操作1.JsonCpp库1.1Json数据格式1.2JsonCpp介绍1.3JsonCpp使用2.Muduo库2.1Muduo库常见接口介绍2.1.1TcpServer类基础介绍2.1.2EventLoop类基础介绍2.1.3TcpConnection类基础介绍2.1.4Buffer类基础介绍2.1.5TcpClient类基础介绍2.2Muduo库实现
- [项目深挖]仿muduo库的并发服务器的解析与优化方案
水墨不写bug
项目实践服务器运维linuxmuduoC++
标题:[项目深挖]仿muduo库的并发服务器的优化方案@水墨不写bug文章目录一、buffer模块(1)线性缓冲区+直接扩容---->环形缓冲区+定时扩容(只会扩容一次)(2)使用双缓冲(DoubleBuffering)(3)数据丢弃策略为什么视频传输选择不可靠的UDP协议?(4)零拷贝为什么零拷贝重要?零拷贝的典型场景传统数据传输的过程零拷贝的过程实现零拷贝的技术1.`sendfile`系统调用
- 【从零实现JsonRpc框架#3】线程模型与性能优化
北海有初拥
JsonRpc框架项目性能优化
1.Muduo的线程模型Muduo基于Reactor模式,采用单线程Reactor和多线程Reactor相结合的方式,通过事件驱动和线程池实现高并发。1.单线程模型核心思想:所有I/O操作(accept、read、write)和业务逻辑均在一个线程中完成。适用场景:低并发、低延迟的简单场景(如代理服务器)。优点:无锁,避免线程间同步开销。逻辑简单,调试方便。缺点:无法充分利用多核CPU。单个长耗时
- 施磊老师基于muduo网络库的集群聊天服务器(四)
Zhuai-行淮
施磊老师集群聊天网络服务器运维
文章目录实现登录业务登录业务代码补全数据库接口:查询,更新状态注意学习一下里面用到的数据库api测试与问题**问题1:****问题2:**用户连接信息与线程安全聊天服务器是长连接服务器如何找到用户B的连接?在业务层存储用户的连接信息多线程安全问题加锁!处理客户端异常退出处理情况:-功能不完善两个任务:测试点对点聊天业务(在线)传什么?业务处理逻辑代码结构规划调试与测试:离线消息存储业务设计数据库表
- 施磊老师基于muduo网络库的集群聊天服务器(三)
Zhuai-行淮
施磊老师集群聊天网络服务器c++linux
文章目录业务模块ChatService网络模块-连接回调实现解耦业务头文件公共头文件业务函数定义文件补充网路模块onMessgae()测试至此mysql数据库代码封装ORM(对象关系映射)框架DAO(DataAccessObject)数据访问对象模式分离数据层与业务层数据库读取头文件数据库类函数源文件使用ORM,实现注册业务**第一步:****第二步:****第三步:**错误1:小技巧--红色波浪
- 施磊老师基于muduo网络库的集群聊天服务器(五)
Zhuai-行淮
施磊老师集群聊天网络服务器php
文章目录添加好友业务实现的功能-简单实现功能不完善表设计-每个表对应一个单独的处理文件业务逻辑:-显然不好,可以改进为什么功能少优化SQL联合查询语句代码结构测试问题群组业务主要功能表设计多表查询:`Group`类`GroupUser`类`GroupModel`(数据访问层)添加群聊业务群组阶段面试问题1.**项目介绍怎么讲**2.**面试官常问点**3.**容易翻车的地方**4.**加分点**5
- 施磊老师基于muduo网络库的集群聊天服务器(二)
Zhuai-行淮
施磊老师集群聊天c++开发语言网络
文章目录Cmake简单介绍Cmake与MakefileCmake配置CmakeLists.txt编写完整cmake例子文件夹杂乱问题多级目录Cmakevscode极其推荐的cmake方式Mysql环境与编程mysql简单使用User表Friend表AllGroup表GroupUser表OfflineMessage表集群聊天项目工程目录创建网络模块代码Chatserver头文件类函数定义文件主函数文
- 手写C++ Muduo网络库项目-掌握高性能网络库实现原理
weixin_59289169
pythonjavaphpc++c语言
学习编程的一个很好的方法就是和其他的程序员交谈。不必谈论任何特定的内容。可以是你正在学习的东西,也可以是你认为很酷的东西,更可以是你正在工作的东西,皆可。你会发现很多程序员并不喜欢只是聊编程。这样做可能会让你学到很多关于库,服务器,编程语言和模式方面的知识。但是,最重要的是,你将了解到其他人是如何看待编程的。你会发现,你认为理所当然或从来没有考虑的事情在人与人之间是非常不同的。还有你遇到的那些小问
- 施磊老师基于muduo网络库的集群聊天服务器(六)
Zhuai-行淮
施磊老师集群聊天网络服务器php
文章目录客户端开发开始客户端首页面功能为何不逐行开发?客户端CMake代码搭配知识补充--有很多漏的客户端main-登录,注册,退出群组有问题测试客户端好友添加与聊天功能表驱动设计:commandMapcommandHandlerMap为什么都是int,string添加好友和聊天功能测试错误解决friend表问题mysql注入--(额外辉)数据表问题客户端开发开始客户端客户端首页面功能为何不逐行开
- __sso_string与std::string的区别
未来老干部
C-C++基础string
在学习muduo库源码的时候在,base文件夹下的type.h有#ifdefMUDUO_STD_STRINGusingstd::string;#else//!MUDUO_STD_STRINGtypedef__gnu_cxx::__sso_stringstring;#endif就想了解一下__sso_string和std::string的区别:主要参考了这篇博客:http://blog.csdn.n
- 封装TCP socket
lynijk
网络编程socket网络c++
封装TCPsocket对字节序转化函数、网络地址、Socket操作函数、监听套接字和连接套接字进行了封装,部分代码参考自muduo网络库源码地址:https://github.com/liuyunian/tools-cxx/tree/master/tools/socket字节序转化函数对于字节序转化函数,Unix和Linux共同拥有的是htonl(),htons(),ntohl(),ntohs()
- muduo库net源码分析八(TcpServer/TcpConnection)
houcaihua
tcp/ip网络网络协议
Acceptor类的主要功能是socket、bind、listen一般来说,在上层应用程序中,我们不直接使用Acceptor,而是把它作为TcpServer的成员TcpServer还包含了一个TcpConnection列表TcpConnection与Acceptor类似,有两个重要的数据成员,Socket与Channel。#ifndefMUDUO_NET_TCPSERVER_H#defineMUD
- mongodb3.03开启认证
21jhf
mongodb
下载了最新mongodb3.03版本,当使用--auth 参数命令行开启mongodb用户认证时遇到很多问题,现总结如下:
(百度上搜到的基本都是老版本的,看到db.addUser的就是,请忽略)
Windows下我做了一个bat文件,用来启动mongodb,命令行如下:
mongod --dbpath db\data --port 27017 --directoryperdb --logp
- 【Spark103】Task not serializable
bit1129
Serializable
Task not serializable是Spark开发过程最令人头疼的问题之一,这里记录下出现这个问题的两个实例,一个是自己遇到的,另一个是stackoverflow上看到。等有时间了再仔细探究出现Task not serialiazable的各种原因以及出现问题后如何快速定位问题的所在,至少目前阶段碰到此类问题,没有什么章法
1.
package spark.exampl
- 你所熟知的 LRU(最近最少使用)
dalan_123
java
关于LRU这个名词在很多地方或听说,或使用,接下来看下lru缓存回收的实现
1、大体的想法
a、查询出最近最晚使用的项
b、给最近的使用的项做标记
通过使用链表就可以完成这两个操作,关于最近最少使用的项只需要返回链表的尾部;标记最近使用的项,只需要将该项移除并放置到头部,那么难点就出现 你如何能够快速在链表定位对应的该项?
这时候多
- Javascript 跨域
周凡杨
JavaScriptjsonp跨域cross-domain
 
- linux下安装apache服务器
g21121
apache
安装apache
下载windows版本apache,下载地址:http://httpd.apache.org/download.cgi
1.windows下安装apache
Windows下安装apache比较简单,注意选择路径和端口即可,这里就不再赘述了。 2.linux下安装apache:
下载之后上传到linux的相关目录,这里指定为/home/apach
- FineReport的JS编辑框和URL地址栏语法简介
老A不折腾
finereportweb报表报表软件语法总结
JS编辑框:
1.FineReport的js。
作为一款BS产品,browser端的JavaScript是必不可少的。
FineReport中的js是已经调用了finereport.js的。
大家知道,预览报表时,报表servlet会将cpt模板转为html,在这个html的head头部中会引入FineReport的js,这个finereport.js中包含了许多内置的fun
- 根据STATUS信息对MySQL进行优化
墙头上一根草
status
mysql 查看当前正在执行的操作,即正在执行的sql语句的方法为:
show processlist 命令
mysql> show global status;可以列出MySQL服务器运行各种状态值,我个人较喜欢的用法是show status like '查询值%';一、慢查询mysql> show variab
- 我的spring学习笔记7-Spring的Bean配置文件给Bean定义别名
aijuans
Spring 3
本文介绍如何给Spring的Bean配置文件的Bean定义别名?
原始的
<bean id="business" class="onlyfun.caterpillar.device.Business">
<property name="writer">
<ref b
- 高性能mysql 之 性能剖析
annan211
性能mysqlmysql 性能剖析剖析
1 定义性能优化
mysql服务器性能,此处定义为 响应时间。
在解释性能优化之前,先来消除一个误解,很多人认为,性能优化就是降低cpu的利用率或者减少对资源的使用。
这是一个陷阱。
资源时用来消耗并用来工作的,所以有时候消耗更多的资源能够加快查询速度,保持cpu忙绿,这是必要的。很多时候发现
编译进了新版本的InnoDB之后,cpu利用率上升的很厉害,这并不
- 主外键和索引唯一性约束
百合不是茶
索引唯一性约束主外键约束联机删除
目标;第一步;创建两张表 用户表和文章表
第二步;发表文章
1,建表;
---用户表 BlogUsers
--userID唯一的
--userName
--pwd
--sex
create
- 线程的调度
bijian1013
java多线程thread线程的调度java多线程
1. Java提供一个线程调度程序来监控程序中启动后进入可运行状态的所有线程。线程调度程序按照线程的优先级决定应调度哪些线程来执行。
2. 多数线程的调度是抢占式的(即我想中断程序运行就中断,不需要和将被中断的程序协商)
a) 
- 查看日志常用命令
bijian1013
linux命令unix
一.日志查找方法,可以用通配符查某台主机上的所有服务器grep "关键字" /wls/applogs/custom-*/error.log
二.查看日志常用命令1.grep '关键字' error.log:在error.log中搜索'关键字'2.grep -C10 '关键字' error.log:显示关键字前后10行记录3.grep '关键字' error.l
- 【持久化框架MyBatis3一】MyBatis版HelloWorld
bit1129
helloworld
MyBatis这个系列的文章,主要参考《Java Persistence with MyBatis 3》。
样例数据
本文以MySQL数据库为例,建立一个STUDENTS表,插入两条数据,然后进行单表的增删改查
CREATE TABLE STUDENTS
(
stud_id int(11) NOT NULL AUTO_INCREMENT,
- 【Hadoop十五】Hadoop Counter
bit1129
hadoop
1. 只有Map任务的Map Reduce Job
File System Counters
FILE: Number of bytes read=3629530
FILE: Number of bytes written=98312
FILE: Number of read operations=0
FILE: Number of lar
- 解决Tomcat数据连接池无法释放
ronin47
tomcat 连接池 优化
近段时间,公司的检测中心报表系统(SMC)的开发人员时不时找到我,说用户老是出现无法登录的情况。前些日子因为手头上 有Jboss集群的测试工作,发现用户不能登录时,都是在Tomcat中将这个项目Reload一下就好了,不过只是治标而已,因为大概几个小时之后又会 再次出现无法登录的情况。
今天上午,开发人员小毛又找到我,要我协助将这个问题根治一下,拖太久用户难保不投诉。
简单分析了一
- java-75-二叉树两结点的最低共同父结点
bylijinnan
java
import java.util.LinkedList;
import java.util.List;
import ljn.help.*;
public class BTreeLowestParentOfTwoNodes {
public static void main(String[] args) {
/*
* node data is stored in
- 行业垂直搜索引擎网页抓取项目
carlwu
LuceneNutchHeritrixSolr
公司有一个搜索引擎项目,希望各路高人有空来帮忙指导,谢谢!
这是详细需求:
(1) 通过提供的网站地址(大概100-200个网站),网页抓取程序能不断抓取网页和其它类型的文件(如Excel、PDF、Word、ppt及zip类型),并且程序能够根据事先提供的规则,过滤掉不相干的下载内容。
(2) 程序能够搜索这些抓取的内容,并能对这些抓取文件按照油田名进行分类,然后放到服务器不同的目录中。
- [通讯与服务]在总带宽资源没有大幅增加之前,不适宜大幅度降低资费
comsci
资源
降低通讯服务资费,就意味着有更多的用户进入,就意味着通讯服务提供商要接待和服务更多的用户,在总体运维成本没有由于技术升级而大幅下降的情况下,这种降低资费的行为将导致每个用户的平均带宽不断下降,而享受到的服务质量也在下降,这对用户和服务商都是不利的。。。。。。。。
&nbs
- Java时区转换及时间格式
Cwind
java
本文介绍Java API 中 Date, Calendar, TimeZone和DateFormat的使用,以及不同时区时间相互转化的方法和原理。
问题描述:
向处于不同时区的服务器发请求时需要考虑时区转换的问题。譬如,服务器位于东八区(北京时间,GMT+8:00),而身处东四区的用户想要查询当天的销售记录。则需把东四区的“今天”这个时间范围转换为服务器所在时区的时间范围。
- readonly,只读,不可用
dashuaifu
jsjspdisablereadOnlyreadOnly
readOnly 和 readonly 不同,在做js开发时一定要注意函数大小写和jsp黄线的警告!!!我就经历过这么一件事:
使用readOnly在某些浏览器或同一浏览器不同版本有的可以实现“只读”功能,有的就不行,而且函数readOnly有黄线警告!!!就这样被折磨了不短时间!!!(期间使用过disable函数,但是发现disable函数之后后台接收不到前台的的数据!!!)
- LABjs、RequireJS、SeaJS 介绍
dcj3sjt126com
jsWeb
LABjs 的核心是 LAB(Loading and Blocking):Loading 指异步并行加载,Blocking 是指同步等待执行。LABjs 通过优雅的语法(script 和 wait)实现了这两大特性,核心价值是性能优化。LABjs 是一个文件加载器。RequireJS 和 SeaJS 则是模块加载器,倡导的是一种模块化开发理念,核心价值是让 JavaScript 的模块化开发变得更
- [应用结构]入口脚本
dcj3sjt126com
PHPyii2
入口脚本
入口脚本是应用启动流程中的第一环,一个应用(不管是网页应用还是控制台应用)只有一个入口脚本。终端用户的请求通过入口脚本实例化应用并将将请求转发到应用。
Web 应用的入口脚本必须放在终端用户能够访问的目录下,通常命名为 index.php,也可以使用 Web 服务器能定位到的其他名称。
控制台应用的入口脚本一般在应用根目录下命名为 yii(后缀为.php),该文
- haoop shell命令
eksliang
hadoophadoop shell
cat
chgrp
chmod
chown
copyFromLocal
copyToLocal
cp
du
dus
expunge
get
getmerge
ls
lsr
mkdir
movefromLocal
mv
put
rm
rmr
setrep
stat
tail
test
text
- MultiStateView不同的状态下显示不同的界面
gundumw100
android
只要将指定的view放在该控件里面,可以该view在不同的状态下显示不同的界面,这对ListView很有用,比如加载界面,空白界面,错误界面。而且这些见面由你指定布局,非常灵活。
PS:ListView虽然可以设置一个EmptyView,但使用起来不方便,不灵活,有点累赘。
<com.kennyc.view.MultiStateView xmlns:android=&qu
- jQuery实现页面内锚点平滑跳转
ini
JavaScripthtmljqueryhtml5css
平时我们做导航滚动到内容都是通过锚点来做,刷的一下就直接跳到内容了,没有一丝的滚动效果,而且 url 链接最后会有“小尾巴”,就像#keleyi,今天我就介绍一款 jquery 做的滚动的特效,既可以设置滚动速度,又可以在 url 链接上没有“小尾巴”。
效果体验:http://keleyi.com/keleyi/phtml/jqtexiao/37.htmHTML文件代码:
&
- kafka offset迁移
kane_xie
kafka
在早前的kafka版本中(0.8.0),offset是被存储在zookeeper中的。
到当前版本(0.8.2)为止,kafka同时支持offset存储在zookeeper和offset manager(broker)中。
从官方的说明来看,未来offset的zookeeper存储将会被弃用。因此现有的基于kafka的项目如果今后计划保持更新的话,可以考虑在合适
- android > 搭建 cordova 环境
mft8899
android
1 , 安装 node.js
http://nodejs.org
node -v 查看版本
2, 安装 npm
可以先从 https://github.com/isaacs/npm/tags 下载 源码 解压到
- java封装的比较器,比较是否全相同,获取不同字段名字
qifeifei
非常实用的java比较器,贴上代码:
import java.util.HashSet;
import java.util.List;
import java.util.Set;
import net.sf.json.JSONArray;
import net.sf.json.JSONObject;
import net.sf.json.JsonConfig;
i
- 记录一些函数用法
.Aky.
位运算PHP数据库函数IP
高手们照旧忽略。
想弄个全天朝IP段数据库,找了个今天最新更新的国内所有运营商IP段,copy到文件,用文件函数,字符串函数把玩下。分割出startIp和endIp这样格式写入.txt文件,直接用phpmyadmin导入.csv文件的形式导入。(生命在于折腾,也许你们觉得我傻X,直接下载人家弄好的导入不就可以,做自己的菜鸟,让别人去说吧)
当然用到了ip2long()函数把字符串转为整型数
- sublime text 3 rust
wudixiaotie
Sublime Text
1.sublime text 3 => install package => Rust
2.cd ~/.config/sublime-text-3/Packages
3.mkdir rust
4.git clone https://github.com/sp0/rust-style
5.cd rust-style
6.cargo build --release
7.ctrl