- 【ARM Cache 与 MMU 系列文章 4 – Cache 与 CPU 乱序执行】
主公讲 ARM
#【ARMCache与MMU/MPU专栏】jvmCPU乱序执行CPUPiplinestorebuffer
请阅读【ARMCache及MMU/MPU系列文章专栏导读】及【嵌入式开发学习必备专栏】文章目录1.1Cache之乱序执行1.1.1CPUPipline1.1.2CacheStoreBuffer引入背景1.1.3CacheStoreBuffer1.1.4InvalidataQueue1.1.5StoreBuffer引入乱序执行1.1.5Invalidqueue引入乱序执行1.1.6内存屏障1.1.7
- 当volatile失效:揭秘Java内存模型的隐匿陷阱与解决方案
悟能不能悟
javajvm开发语言
从CPU缓存一致性问题到JDK新内存屏障实战问题背景资深Java面试题:“假设存在以下基于volatile的并发代码:publicclassVolatileExample{privatevolatilebooleanflag=false;privateintcounter=0;publicvoidwriter(){counter=42;//非volatile写flag=true;//volatil
- Voliate关键字的作用
玄魄灵归
Javajavajava-eejvm
Voliate关键字主要有以下两个作用:一:内存可见性基于缓存一致性协议,当系统或者程序中某个变量发生修改时,此时cpu会同时其他线程,告诉被通知的线程缓存内容已经被修改,通知i线程需要更新缓存,这样每个线程都能获取到最新的变量值。二:基于内存屏障的防止指令重排用Voliate修饰的变量,可以防止cpu执行指令重排序,底层的实现方式是基于4中内存屏障:读读,读写,写读,写写屏障。
- linux内存屏障
嵌入式产品侠
Linux内核linux内存屏障smbrmb
why?为什么要有内存屏障,内存屏障主要解决什么问题What?内存屏障都有哪些How?内存屏障如何使用本篇文章主要解决前两个问题一、为什么要有内存屏障我们都知道计算机运算任务需要CPU和内存相互配合共同完成,其中CPU负责逻辑计算,内存负责数据存储。CPU要与内存进行交互,如读取运算数据、存储运算结果等。由于内存和CPU的计算速度有几个数量级的差距,为了提高CPU的利用率,现代处理器结构都加入了一
- Java高频面试之并发编程-16
牛马baby
java面试开发语言
hello啊,各位观众姥爷们!!!本baby今天又来报道了!哈哈哈哈哈嗝面试官:volatile实现原理是什么?volatile关键字的实现原理volatile是Java中用于解决多线程环境下变量可见性和指令重排序问题的关键字。其实现原理基于JVM内存屏障(MemoryBarriers)和硬件层面的缓存一致性协议(如MESI)。以下是详细分析:1.核心作用可见性:确保一个线程对volatile变量
- volatile原理(内存屏障)
小羊Go
javaidea
volatile场景一个线程写,其他线程读的情况double-check-lock时,synchronized同步代码块外共享变量的指令重排序问题同步机制volatile是Java虚拟机提供的轻量级的同步机制(三大特性)保证可见性不保证原子性保证有序性(禁止指令重排)性能:volatile修饰的变量进行读操作与普通变量几乎没什么差别,但是写操作相对慢一些,因为需要在本地代码中插入很多内存屏障来保证
- 【Rust并发编程深度解析:内存模型与异步运行时实现原理】
蝉叫醒了夏天
rust开发语言后端
Rust并发编程深度解析:内存模型与异步运行时实现原理一、内存模型的硬件层实现1.1x86-TSO与ARMv8内存模型对比内存屏障指令对照表:架构Load屏障Store屏障全屏障x86lfence(弱语义)sfencemfenceARMdmbishlddmbishstdmbishRISC-Vfencer,rfencew,wfencerw,rw缓存一致性协议MESI改进型:{MESIF(Intel)
- Kafka 消息可靠性深度解析:大流量与小流量场景下的设计哲学
fjkxyl
kafka分布式
在分布式消息系统的设计中,消息可靠性保障本质上是系统在一致性、可用性、吞吐量三者之间动态博弈的结果。Kafka作为现代流式架构的核心组件,其消息可靠性机制在不同流量场景下呈现出截然不同的设计哲学。本文将从系统设计原理层面,解构大流量与小流量场景下的可靠性保障机制差异,揭示背后的分布式系统设计智慧。一、生产者可靠性机制:网络协议层的博弈1.大流量场景:最终一致性的吞吐量优化异步批处理与内存屏障Kaf
- linux spinlock 时间同居,Linux内核:spinlock和睡眠
我不是蟾蜍先生
linuxspinlock时间同居
spinlock是linux内核锁机制的一种,而linux内核锁机制是linux内核同步机制的一部分。linux内核同步机制的使用原因是为了避免共享数据之间的竞争出现,它包括percpu变量、原子操作、内存屏障、spinlock、信号量、顺序锁、禁止本地中断、禁止本地软中断、RCU等等。linux内核同步机制与SMP、抢占、可延迟函数、工作队列等等紧密关联。由于复杂性的原因,在此并不对整个linu
- Java并发编程-volatile关键字详解及案例实战
猿与禅
Java技术栈源码分析javavolatile并发编程
文章目录volatile关键字的作用手写一个小程序来体验一下volatile关键字的作用讲解volatile是如何保证可见性的Java内存模型(JMM)volatile的工作原理实现可见性的总结volatile为什么无法保证原子性基于happens-before原则来看volatile如何保证有序性volatile的底层实现原理:lock指令以及内存屏障Lock前缀指令内存屏障(MemoryBar
- 互联网三高架构分析
红云梦
架构java
1高性能提升系统处理效率,降低延迟(响应时间≤200ms),提高吞吐量(QPS/TPS)。可以从以下几个方面考虑:①JVM调优与垃圾回收机制优化,降低内存占用和GC频率,目标就是减少STW②池化技术(线程池、连接池)减少资源创建销毁开销,提升响应速度③无锁编程,通过原子操作和内存屏障实现线程同步的技术,旨在消除传统锁机制的性能瓶颈和死锁风险④高性能IO零拷贝技术:通过sendfile、mm
- 每日一道Java面试题(1)
辑安24
java开发语言单例模式
每日一道Java面试题请解释volatile关键字在Java中的作用,并举例说明其使用场景。解析1.volatile的作用volatile是Java中的轻量级同步机制,主要解决多线程环境下的可见性和有序性问题,但不保证原子性。可见性:当一个线程修改了volatile变量的值,其他线程能立即看到最新的值(强制从主内存读取,而不是本地缓存)。有序性:禁止指令重排序优化(通过插入内存屏障)。2.原理可见
- Java volatile 关键字详解
27xixi
java高频java单例模式开发语言
Javavolatile关键字详解1.volatile的作用与原理可见性保证:volatile修饰的变量在修改后,会立即同步到主内存,其他线程读取时直接从主内存获取最新值,确保多线程环境下的可见性。例如:volatilebooleanflag=false;当线程A修改flag为true后,线程B能立即感知到变化。禁止指令重排序:volatile通过插入内存屏障(MemoryBarrier)禁止编译
- 多线程--volatile关键字
帅的飞起来
多线程java多线程
volatile是java中的一个关键字,用于修饰变量,主要解决多线程环境下的可见性和有序性问题。一、volatile的作用可见性:保证一个线程对volatile变量的修改对其他线程立即可见有序性:禁止指令重排序,确保代码的执行顺序与编写顺序一致(关于可见性和有序性请参考多线程JMM)二、内存屏障的类型1、LoadLoadBarrier示例:Load1;LoadLoad;Load2,确保Load1
- Java并发编程:深入理解volatile、线程安全陷阱与复合操作
有诺千金
Java并发编程java安全单例模式
一、volatile关键字详解1.核心作用可见性:对volatile变量的写操作立即刷新到主内存,读操作直接读取主内存。有序性:禁止指令重排序(通过内存屏障),确保代码执行顺序符合预期。局限性:不保证原子性(如i++需配合锁或原子类)。2.底层原理JMM层面:插入内存屏障(如StoreLoad屏障),强制缓存同步。硬件层面:依赖CPU的MESI协议实现缓存行失效。3.正确使用场景状态标志:单次写入
- 深入解析Java线程锁机制:从原理到最佳实践
XU磊260
JAVAjava
##引言在多线程编程中,线程安全是开发者面临的核心挑战之一。当多个线程并发访问共享资源时,如果没有正确的同步机制,就可能出现数据不一致、竞态条件等问题。Java提供了多种线程锁机制来保障线程安全,本文将深入探讨Java中的各种锁实现、使用场景和优化策略。一、线程锁的核心作用1.1互斥访问确保同一时刻只有一个线程可以访问临界区代码,防止并发修改导致的数据不一致。1.2可见性保证通过锁机制强制内存屏障
- 量化交易技术简介
0010000100
linux
量化交易1.C++技术栈高频交易和低延迟系统对C++和Linux内核的要求极高,需要高效的代码执行、低延迟的通信机制、以及对操作系统底层的深入优化。以下是关键技术点:1.C++技术栈高频交易需要极致的性能优化,因此C++代码需要低延迟、高吞吐,通常采用以下技术:(1)高性能数据结构•Lock-free数据结构(无锁队列、环形缓冲区)•采用std::atomic和内存屏障(memorybarrier
- volatile 和 Threadlocal 的原理和适用场景
「已注销」
javajavavolatile
volatile原理volatile能保证可见性和一定程度的顺序性。变量被volatile修饰时,线程对变量进行写操作时jvm会向处理器发送lock前缀指令,lock前缀指令相当于内存屏障。内存屏障的功能写操作修改的值会立即刷新到主内存,并设置其他线程的缓存无效,线程读取变量必需从主内存读取新值,保证了可见性。禁止指令重排序,后面的指令不能再内存屏障之前,前面的指令不能再内存屏障之后,保证一定程度
- 《Memory Barriers a Hardware View for Software Hackers》阅读笔记
落樱弥城
基础知识c++笔记
CPU设计者引入内存屏障(memorybarriers)是为了应对在多处理器系统(SMP)中,内存引用重排序可能导致的同步问题。尽管重排序可以提高性能,但在某些情况下(如同步原语),正确的操作依赖于有序的内存引用,因此需要使用内存屏障来强制执行顺序。 要深入理解这个问题,需要了解CPU缓存的工作原理,尤其是如何使缓存有效工作。以下是相关内容的概述:缓存结构:介绍缓存的基本结构和工作机制。缓存
- iOS - 内存屏障的使用场景
Batac_蝠猫
iOS底层原理objective-c开发语言macos
内存屏障的使用是为了解决以下几个关键问题:1.CPU乱序执行//没有内存屏障时,CPU可能乱序执行voidexample(){//这两行代码可能被CPU重排序a=1;//操作1flag=true;//操作2}//使用内存屏障确保顺序voidsafeExample(){a=1;OSMemoryBarrier();//确保a=1在flag=true之前完成flag=true;}2.多核CPU的缓存一致
- ARM内存屏障/编译屏障API(__DMB、__DSB、__ISB)用法及举例
NW嵌入式开发
ARM内核Cortex-A7stm32MP135内存屏障编译屏障DMBDSBISB
0参考资料STM32F7SeriesandSTM32H7SeriesCortex®-M7processor.pdfARMCortex™-MProgrammingGuidetoMemoryBarrierInstructions.pdf1ARM内存屏障/编译屏障指令(__DMB、__DSB、__ISB)说明内存屏障和编译屏蔽其实是2个东西,一个是处理器运行时避免乱序引入的指令,一个是编译时避免编译器编
- volatile的实现
狼与自由
java
字节码层面ACC_VOLATILEJVMvolatile内存区的读写都加了内存屏障OS和硬件层面windowslock指令实现
- Java并发编程之Volatile原理
逍遥白亦
Volatile定义Java语言规范第3版中对volatile的定义如下:Java编程语言允许线程访问共享变量,为了确保共享变量能被准确和一致地更新,线程应该确保通过排他锁单独获得这个变量。Java语言提供了volatile,在某些情况下比锁要更加方便。如果一个字段被声明成volatile,Java线程内存模型确保所有线程看到这个变量的值是一致的。CPU的相关术语术语术语描述内存屏障用一组处理器指
- 分布式锁实现
码<>农
分布式linux服务器c语言数据结构算法链表
在分布式系统中,一个应用部署在多台机器中,在某些场景下,为了保证数据一致性,要求在同一时刻,同一任务只在一个节点上运行,即保证某个行为在同一时刻只能被一个线程执行;在单机单进程多线程环境,通过锁很容易做到,比如mutex,spinlock,信号量等;而在多机多进程环境中,此时就需要分布式锁来解决了;常见的锁有互斥锁,自旋锁,读写锁,信号量,条件变量,原子变量和内存屏障(无锁);互斥锁和自旋锁是互斥
- [architecture]-DMB、DSB 和 ISB指令的深度解读
代码改变世界ctw
ARM-TEE-Androidarmv9DMBDSBISB内存屏障
快速链接:.个人博客笔记导读目录(全部)付费专栏-付费课程【购买须知】:【精选】ARMv8/ARMv9架构入门到精通-[目录]术语:DMB–DataMemoryBarrierDSB–DataSynchronizationBarrierISB–InstructionSynchronizationBarrier思考:内存屏障到底屏的什么?为什么要用内存屏障?乱序执行是怎样的一个乱序?为什么会出现乱序
- volatile源码解析【解决可见性(依据happened-befor)有序性(依据内存屏障)】
_蓝天IT_
java
volatile源码解析解决内存可见性问题volatile实现原理-源码分析转自极客时间解决内存可见性问题volatile实现原理-源码分析
- 聊聊高并发(一)概念
wenming6688
并发/线程的一些概念,概念很重要,没有理论指导的话会导致理解不够全面多线程问题的本质--有序性,可见性,原子性synchronize的底层实现volatile的底层实现无锁算法的底层实现--CAS原子变量的实现final关键字的新含义深入理解Java内存模型指令重排序和内存屏障顺序一致性和Happens-before规则一些基本的硬件知识一些处理同步问题的技术
- 一篇长文简短介绍,Linux内核——内存屏障(建议收藏)
极致Linux内核
在阅读很多底层的代码时,经常会碰到一个所谓内存屏障的概念,经常搞得一头雾水。本文将对这个概念进行一个系统的介绍。一、为什么需要内存屏障内存屏障的引入,本质上是由于CPU重排序指令引起的。重排序问题无时无刻不在发生,主要源自以下几种场景:编译器编译时的优化;处理器执行时的多发射和乱序优化;读取和存储指令的优化;缓存同步顺序(导致可见性问题)。下面分别解释一下:编译器优化编译器在不改变单线程程序语义的
- Java多线程相关学习
许水愿
Java基础Java多线程Java并发
Java多线程文章目录Java多线程线程状态线程切换状态图线程终止内存屏障和CPU缓存CPU的优化手段-缓存缓存同步协议运行时指令重排CPU存在的两个问题内存屏障解决上两个问题线程通信通信的方式API-被弃用的suspend和resumewait/notify机制park/unpark机制伪唤醒线程封闭ThreadLocal栈封闭线程池应用及原理为什么要用线程池线程池的基本概念线程池API-接口定
- Java内存模型的抽象结构:理解并发编程的关键
小阳小朋友
并发java开发语言
文章目录前言一、主内存与本地内存二、内存屏障与操作类型三、原子性、可见性与有序性四、总结前言在多线程编程中,内存模型是一个核心概念,它决定了线程如何共享和访问数据。Java内存模型(JMM)是Java平台规范中定义的一组规则和协议,用于描述线程之间如何通过共享内存进行交互。本文将深入探讨Java内存模型的抽象结构,帮助读者更好地理解并发编程中的原子性、可见性和有序性。一、主内存与本地内存Java内
- 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