public class main {
private int count = 10;
private int time = 50;
public static void main(string[] args) {
//初始化log4j,zookeeper否则报错。
//org.apache.log4j.basicconfigurator.configure();
try {
main app = new main();
app.zk();
} catch (exception e) {
e.printstacktrace();
}
}
private void zk() throws exception {
//任意位置的sharedcount,只要使用相同的path,都可以得到这个计数值。
string path = “/path/count”;
curatorframework client = initclient(path);
//分布式集群中存在的某一处计数。
sharedcount basecount = new sharedcount(client, path, 0);
basecount.start();
//basecount.setcount(0);
basecount.addlistener(new sharedcountlistener() {
@override
public void counthaschanged(sharedcountreader sharedcount, int newcount) throws exception {
system.out.println(“counthaschanged最新=” + newcount);
}
@override
public void statechanged(curatorframework client, connectionstate newstate) {
//system.out.println(tag + “状态变化:” + client.tostring());
}
});
list sharedcountlist = new arraylist();
//开启count个线程,模拟对分布式中sharedcount的不同节点的赋值操作。
executorservice service = executors.newfixedthreadpool(count);
for (int i = 0; i < count; i++) {
sharedcount count = new sharedcount(client, path, 0);
count.start();
sharedcountlist.add(count);
runnable runnable = new runnable() {
@override
public void run() {
try {
timeunit.seconds.sleep((long) (math.random() * time));
setvalue(count);
} catch (exception e) {
e.printstacktrace();
}
}
};
service.submit(runnable);
}
service.shutdown();
service.awaittermination(time, timeunit.seconds);
//使用完成后要记得关闭。
for (sharedcount c : sharedcountlist) {
c.close();
}
basecount.close();
}
private void setvalue(sharedcount count) throws exception {
system.out.println(“-------------”);
int oldcount = count.getcount();
system.out.println(“当前值=” + oldcount);
system.out.println(“当前versionedvalue version=” + count.getversionedvalue().getversion());
system.out.println(“当前versionedvalue value=” + count.getversionedvalue().getvalue());
int n = (int) (math.random() * 1000);
system.out.println(“尝试赋值:” + n);
/**
-
trysetcount设置计数器和setcount不同,setcount强制更新计数器的值。
-
trysetcount第一个参数提供当前的versionedvalue,如果期间其它client更新了计数值,
-
你的更新可能不成功,但是这时你的client更新了最新的值,
-
若失败可再尝试更新。
-
只有当此client最后读取的值与zookeeper中的值相等时,才能更新.
-
调用此方法,不成功时,会刷新本地缓存值.
-
之后调用getcount()就是新值.
*/
//boolean b = count.trysetcount(count.getversionedvalue(), n);
//system.out.println(n + “更新?” + b);
//或者使用setcount强制更新计数器的值。
//此方法强制更新计数器值。
count.setcount(n);
}
private curatorframework initclient(string path) throws exception {
curatorframework client = makeclient();
client.start();
boolean b = ispathexist(client, path);
//如果不存在这个路径,stat为null,创建新的节点路径。
if (!b) {
string s = client.create()
.creatingparentsifneeded()
.withmode(createmode.persistent)
.forpath(path);
system.out.println("创建 " + s);
} else {
system.out.println(“已存在:” + path + “,不需重复创建”);
}
return client;
}
//检测是否存在该路径。
private boolean ispathexist(curatorframework client, string path) {
boolean b = false;
//检测是否存在该路径。
try {
stat stat = client.checkexists().forpath(path);
b = stat == null ? false : true;
} catch (exception e) {
e.printstacktrace();
}
return b;
}
private curatorframework makeclient() {
retrypolicy retrypolicy = new exponentialbackoffretry(1000, 5);
curatorframework client = curatorframeworkfactory.builder()
.connectstring(getaddress())
.sessiontimeoutms(10 * 1000)
.connectiontimeoutms(20 * 1000)
.retrypolicy(retrypolicy)
.build();
return client;
}
private string getaddress() {
string ip = “127.0.0.1”;
return ip + “:2181,” + ip + “:2182,” + ip + “:2183”;
}
}
输出:
创建 /path/count
当前值=825700910
当前versionedvalue version=0
最后
今天关于面试的分享就到这里,还是那句话,有些东西你不仅要懂,而且要能够很好地表达出来,能够让面试官认可你的理解,例如handler机制,这个是面试必问之题。有些晦涩的点,或许它只活在面试当中,实际工作当中你压根不会用到它,但是你要知道它是什么东西。
最后在这里小编分享一份自己收录整理上述技术体系图相关的几十套腾讯、头条、阿里、美团等公司2021年的面试题,把技术点整理成了视频和pdf(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节,由于篇幅有限,这里以图片的形式给大家展示一部分。
还有 高级架构技术进阶脑图、android开发面试专题资料,高级进阶架构资料 帮助大家学习提升进阶,也节省大家在网上搜索资料的时间来学习,也可以分享给身边好友一起学习。
【算法合集】
【延伸android必备知识点】
【android部分高级架构视频学习资源】
android精讲视频领取学习后更加是如虎添翼!进军batj大厂等(备战)!现在都说互联网寒冬,其实无非就是你上错了车,且穿的少(技能),要是你上对车,自身技术能力够强,公司换掉的代价大,怎么可能会被裁掉,都是淘汰末端的业务curd而已!现如今市场上初级程序员泛滥,这套教程针对android开发工程师1-6年的人员、正处于瓶颈期,想要年后突破自己涨薪的,进阶android中高级、架构师对你更是如鱼得水,赶快领取吧!
《android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,,即可获取!
g-dvlwcpvo-1715148650544)]
【android部分高级架构视频学习资源】
android精讲视频领取学习后更加是如虎添翼!进军batj大厂等(备战)!现在都说互联网寒冬,其实无非就是你上错了车,且穿的少(技能),要是你上对车,自身技术能力够强,公司换掉的代价大,怎么可能会被裁掉,都是淘汰末端的业务curd而已!现如今市场上初级程序员泛滥,这套教程针对android开发工程师1-6年的人员、正处于瓶颈期,想要年后突破自己涨薪的,进阶android中高级、架构师对你更是如鱼得水,赶快领取吧!
《android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,,即可获取!
发表评论