- Redis为什么要自定义序列化?如何实现自定义序列化器?
小马不敲代码
后端redis序列化
在Redis中,通常会使用自定义序列化器,那么,Redis为什么需要自定义序列化器,该如何实现它?1、为什么需要自定义序列化器?整体来说,Redis需要自定义序列化器,主要有以下几个原因:1.1性能优化序列化效率:默认的序列化器(如Java的JDK序列化)可能效率较低,尤其是在处理大型对象或高并发场景下。反序列化效率:快速的反序列化可以减少应用响应时间,提升整体性能。1.2存储空间优化紧凑的存储格
- 面试基础--分布式一致性算法深度解析
WeiLai1112
后端面试分布式算法java后端架构springboot
分布式一致性算法深度解析:RaftvsPaxos原理、实践与源码实现引言在分布式系统设计中,一致性算法是确保多节点数据同步和系统高可用的核心技术。Raft和Paxos作为两种最经典的分布式一致性算法,支撑了Etcd、ZooKeeper、TiDB等众多核心基础设施。本文将从算法原理、工程实践、源码实现三个维度对比Raft与Paxos,结合大厂真实案例,为分布式系统设计提供选型与实现指南。1.分布式一
- 面试基础---分布式架构基础:CAP 理论与 BASE
WeiLai1112
后端面试redisjunitjava架构分布式后端
分布式架构基础:CAP理论与BASE理论深度解析引言在互联网大厂的高并发、高可用场景下,分布式系统的设计是至关重要的。CAP理论和BASE理论是分布式系统设计的基石,理解这些理论对于设计高可用、高性能的分布式系统至关重要。本文将深入探讨CAP理论和BASE理论,结合实际项目案例和源码分析,帮助读者深入理解其实现原理。1.CAP理论CAP理论是分布式系统设计的基础理论之一,由EricBrewer在2
- Django+Vue创建项目前后端分离
我就是我是好孩子啊
djangovue.jspython
转载掘金文章详细介绍了如何搭建项目https://juejin.cn/post/7028812676230807582Django的TemplateView指向生成的前端dist文件即可.1、找到project目录的urls.py,使用通用视图创建最简单的模板控制器,访问『/』时直接返回index.html:fromdjango.conf.urlsimporturlfromdjango.views
- java byte序列化,java对象序列化byte[] and byte[]反序列化对象--转
xiangzi92
javabyte序列化
importjava.io.ByteArrayInputStream;importjava.io.ByteArrayOutputStream;importjava.io.IOException;importjava.io.ObjectInputStream;importjava.io.ObjectOutputStream;publicclassObjectAndByte{/***对象转数组*@pa
- 前后端分离实践
hinihaoaaa
JS前后端分离
前后端分离并不是什么新鲜事,到处都是前后端分离的实践。然而一些历史项目在从一体化Web设计转向前后端分离的架构时,仍然不可避免的会遇到各种各样的问题。由于层出不穷的问题,甚至会有团队质疑,一体化好好的,为什么要前后端分离?说到底,并不是前后分离不好,只是可能不适合,或者说……设计思维还没有转变过来……一体式Web架构示意前后分离式Web架构示意为什么要前后端分离比为什么要前后端分离更现实的问题是什
- 设计模式——策略模式以及基于Spring依赖注入的策略模式的应用
新停浊酒杯
设计模式策略模式
好的,策略模式(StrategyPattern)是一种行为型设计模式,用于定义一系列算法,并将每个算法封装成独立的类,使得它们可以相互替换。策略模式的核心思想是将算法与使用算法的客户端解耦,让算法的变化独立于客户端的使用。1.策略模式的核心概念策略接口(StrategyInterface)定义所有支持的算法的公共接口,所有具体策略类必须实现该接口。具体策略类(ConcreteStrategies)
- Java多线程 理发店小测试
不被定义的~wolf
Java多线程java安全
功能需求如下:一个理发店里有两张理发椅子,各有一个理发师(线程),还有5张用户椅子。初始主线程每间隔100毫秒产生一个用户(线程),连续产生20名用户。一个用户理发需要300毫秒。用户线程的逻辑:1)如果理发店客满(两个理发师正忙理发,5张客户椅子有人坐着等待),理发店外的用户(线程),将在外等待。2)但理发店中一张用户椅子空,则允许一个用户进入并坐上椅子等待。3)但一个用户理完发,允许5张椅子上
- 全面掌握Python&Java分层自动化测试:从单元测试到安全检测的完整指南
jardonwang1
pythonjava
分层自动化(LayeredAutomation)是一种软件测试策略,通过将自动化测试分为不同层次或阶段,针对不同类型的测试需求,确保测试覆盖的全面性以及提高测试效率。这种方法通过分解复杂的测试任务,将其分配到适当的层级,从而降低测试的维护成本并提高自动化测试的稳定性和复用性。通常,分层自动化包括以下几层:1.单元测试层(UnitTestLayer)定义:单元测试是针对代码中的最小功能单元(通常是函
- Linux 应用开发: SQLite 数据库交叉编译部署与运用
鱼弦
Linux系统编程与驱动开发数据库linuxsqlite
鱼弦:公众号【红尘灯塔】,CSDN博客专家、内容合伙人、新星导师、全栈领域优质创作者、51CTO(Top红人+专家博主)、github开源爱好者(go-zero源码二次开发、游戏后端架构https://github.com/Peakchen)Linux应用开发:SQLite数据库交叉编译部署与运用介绍本指南介绍如何在Linux系统中交叉编译SQLite数据库并将其部署到嵌入式系统中。交叉编译允许在
- 【Gee-Web框架】【Day6】【Golang】模板Template
行者无疆xcc
GeeWeb前端golang开发语言
实现静态资源服务StaticResource支持HTML模板渲染一、服务端渲染1.简要说明前后端分离的开发模式,web后端提供RESTful接口,返回结构化的数据(通常是JSON或者XML),前端使用AJAX技术请求到所需的数据,利用JavaScript进行渲染。Vue/React等前端框架火热,优势突出后端专注解决资源利用、并发、数据库等问题,只需考虑数据如何生成前端专注界面设计实现,只需要考虑
- 判断一个数是否是素数——Java(进阶高效算法)
Pniubi
Java错题集算法java
本文续写上一篇文章:判断一个数是否是素数——Java(初阶低效算法)上一篇中的for循环是从3直到n-1,这里通过Math.sqrt(n)的方法做出改进,使得循环的次数变少以加快运算效率和速率一、Math.sqrt(n)实际上就是开方如果一个数n不是质数,那么它一定可以分解成两个因数a和b,其中a*b=n。如果两个因数都大于sqrt(n),那么它们的乘积将大于n,这与a*b=n矛盾。因此,至少有一
- redis分布式锁
JLiuli
redis分布式锁java
什么是分布式锁在分布式系统下,通过锁机制来控制资源的访问,与传统的单体项目中的synchronized,他是基于jvm的锁,即在一个springboot服务下能保证线程同步的问题,但现在我们大部分的项目部署不局限于一台服务器,此时会出现多把jvm锁无法保证对数据的互斥原则。分布式锁就像是把锁单独抽出来为一个应用,让所有springboot项目公用同一把锁。分布式锁的特点1.互斥性:任意时刻锁只能被
- Java高频面试之集合-05
牛马baby
java面试开发语言
hello啊,各位观众姥爷们!!!本baby今天来报道了!哈哈哈哈哈嗝面试官:快速失败(fail-fast)和安全失败(fail-safe)分别是什么?快速失败(Fail-Fast)与安全失败(Fail-Safe)详解1.快速失败(Fail-Fast)定义:系统在检测到可能导致错误或异常的条件时,立即终止当前操作并抛出异常/错误,避免程序在错误状态下继续运行。其核心思想是“尽早暴露问题”。核心特点
- SpringBoot 启动报错 Sactive: @spring.profiles.active@
JefferyAnd
springspringboot后端
org.yaml.snakeyaml.scanner.ScannerException:whilescanningforthenexttokenfoundcharacter'@'thatcannotstartanytoken.(Donotuse@forindentation)in'reader',line25,column13:active:@spring.profiles.active@^解决办
- 社团周报系统可行性研究-web后端框架对比-springboot,django,gin
拉玛干
数据库springpythongolang
对于目前市面上web后端框架,我主要了解到的就是springboot,djangogin等,分别对应javapythongo三种语言,目前我比较熟悉的就是springboot目录springboot框架简介优点缺点适用场景与需求匹配度django框架简介优点缺点适应场景与需求匹配度gin框架简介优点缺点适用场景与需求匹配度springboot框架简介Spring是一款开源的轻量级java开发框架,
- 在Vue中,onLoad,onShow ,mounted的区别
檐角小猫
vue.js前端javascript
1.onLoad触发时机:页面首次加载时触发,且只会触发一次。适用场景:适合在页面加载时执行一次性操作,比如获取页面参数、初始化数据、发送请求等。特点:可以接收页面传递的参数(通过options对象)。是UniApp页面生命周期钩子,不是Vue组件的钩子。示例代码javascriptexportdefault{onLoad(options){console.log('页面加载,参数为:',opti
- Keras深度学习实战——手写文字识别
鱼弦
机器学习设计类系统深度学习keras人工智能
鱼弦:公众号【红尘灯塔】,CSDN博客专家、内容合伙人、新星导师、全栈领域优质创作者、51CTO(Top红人+专家博主)、github开源爱好者(go-zero源码二次开发、游戏后端架构https://github.com/Peakchen)Keras深度学习实战——手写文字识别1.介绍本教程将介绍如何使用Keras深度学习框架进行手写文字识别。手写文字识别是指将手写文字转换为相应的文本,该文本可
- MySQL主从架构配合ShardingJdbc实现读写分离
eddie_k2
#ShardingJdbcMySQLmysql架构数据库
文章目录目录架构搭建读写分离pom.xmlfdy-live-user-provider模块application.ymlfdy-db-sharding.yamlShardingJdbcDatasourceAutoInitConnectionConfig.java目录架构搭建基于Docker去创建MySQL的主从架构读写分离pom.xmlmysqlmysql-connector-java${fdy-
- Mybatis-Plus 批量插入速度慢的问题优化
自在如风。
mybatismybatis-plusmysqlsqljava
MyBatis-Plus的batchSave接口:实现分页批量插入在实际开发中,批量插入数据是一个常见需求,尤其当数据量较大时,直接使用循环插入效率低下,而MyBatis-Plus提供了强大的批量操作支持。本文将详细讲解如何通过配置和代码实现batchSave接口的分页批量插入功能,优化性能并避免内存溢出。1.背景介绍MyBatis-Plus的BaseMapper默认提供了insert方法,但它只
- 电商系统设计专题系列的第一篇:概述与总体架构
不出名的架构师
架构
1.1系统目标电商系统旨在构建一个高效、可扩展、模块化的平台,支持多种业务模式(如B2C、C2C、B2B),覆盖从用户前端交互到后端供应链管理、财务结算的全流程。主要目标包括:用户体验:提供流畅的购物流程(商品浏览、购物车、支付等)。业务支持:支持商品管理、订单处理、营销活动、物流配送等核心功能。生态整合:对接供应商、服务商、第三方支付等外部系统。数据驱动:通过大数据分析优化定价、库存和用户服务。
- Java项目中ES作为时序库
大丈夫在世当日食一鲲
javaelasticsearch开发语言
一、ES作为时序库的核心优势高写入性能通过BulkAPI支持批量插入/更新,优化吞吐量,适合流式数据(如监控指标、IoT设备数据)的高频写入。使用Logstash作为数据管道时,可通过调整pipeline.workers和batch.size进一步提升并发处理能力。高效的查询与分析倒排索引:对文本字段(如标签)的分词处理,支持快速多条件匹配(如tagslike‘%tag1%’ANDtagslike
- ZooKeeper的初识(Zookeeper基本知识,ZooKeeper shell,ZooKeeper数据模型 ,ZooKeeper Watcher 监听机制,ZooKeeper选举机制)
kismetG
AzkabanZookeeper基本知识ZooKeepershellZooKeeper数据模型ZooKeeperWatcher监听机制ZooKeeper选举机制
Zookeeper基本知识Zookeeper集群搭建Zookeeper集群搭建指的是ZooKeeper分布式模式安装。通常由2n+1台servers组成。这是因为为了保证Leader选举(基于Paxos算法的实现)能过得到多数的支持,所以ZooKeeper集群的数量一般为奇数。Zookeeper运行需要java环境,所以需要提前安装jdk。对于安装leader+follower模式的集群,大致过程
- Ubuntu快速安装kafka集群
拥抱世界的精彩
kafka集群ubuntu搭建kafka集群kafka集群
搭建集群做少需要三台服务器一个centos和两个ubuntu每台都按照下面做:安装JDKsudoapt-getinstalldefault-jrejava-versionapt-getinstalldefault-jdkjava-version安装:sudoapt-getinstallzookeeper/etc/init.d/zookeeperstart//自启动默认信息:#安装路径/usr/sh
- 如何修改并重新封装initrd.img
xxmailk
linuxlinux
如何查看initrd.img文件?initrd.img是gzip格式的文件.先把initrd.img重命名为initrd.gz.#cp/tftpboot/el5/initrd.img.#lscdrominitrd.img#mvinitrd.imginitrd.gzUnziptheinitrd.gzfileasshownbelow.#gunzipinitrd.gz#lscdrominitrd解压缩i
- linux上卸载kafka,kafka安装在linux上的安装
飞鼠明天做窝
linux上卸载kafka
kafka安装第一关java的安装捞得嘛,不谈第二关zookeeper的安装及配置1.直接打开Apachzookeeper进行下载Tips:source是源文件,需要编译后才能继续使用,所以一般直接下载上面的源文件。2.安装zookeeper传到linux里面进行解压3.配置zookeeper打开/etc/profile文件进行配置exportZOOKEEPER_INSTALL=/usr/loca
- React Native 0.78版本发布
wayne214
reactnative
这个版本在ReactNative中集成了React19,还带来了一些其他相关特性,比如原生支持Android矢量图形(AndroidVectordrawables),以及在iOS上更好的混合开发(brownfieldintegration)体验。亮点React19迈向更小巧、更快速的版本发布Metro中JavaScript日志的可选开启功能新增对AndroidXML图形资源的支持iOS上的Reac
- Java连接Zookeeper,创建监听通知机制
永旗狍子
SpringLinuxzookeeperjava
目录一.Java连接Zookeeper1.创建Springboot工程,导入依赖1.1排除log4j和桥接包2.配置application.yml3.编写连接Zookeeper的工具类4.监听通知机制4.1在zookeeper容器内部新增节点一.Java连接Zookeeper1.创建Springboot工程,导入依赖org.springframework.bootspring-boot-start
- Zookeeper系列——节点监听机制,JAVA API
简明编程
笔记微服务与中间件大数据splunkjavajava-zookeeperzookeeper
Zookeeper系列——节点监听机制,JAVAAPI节点监听机制监测类型设置监听监听节点目录监听节点数据JAVAAPIQuickStart1.导入依赖2.测试连接3.关闭完整代码方法创建节点获取节点数据信息删除节点查看节点下的子节点查看节点状态修改节点数据监听节点数据变化(永久监听)监听节点目录变化(永久监听)节点监听机制客户端可以监测znode节点的变化。znode节点的变化触发相应的事件,然
- WebSocket的详解
小陆不会敲代码
网络websocket网络协议网络学习笔记node.js
文章目录前言一、WebSocket是什么?二、WebSocket使用示例前端部分(JavaScript)后端部分(Node.js示例)三、WebSocket心跳机制前端心跳示例后端心跳检测示例(Node.js)四、WebSocket常用事件:五、WebSocket使用场景五、总结前言WebSocket是一种网络通信协议,它提供了一个全双工的通信通道,允许服务器与客户端之间进行实时数据交换。与传统的
- 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