草庐IT

MongoDB同步到ES

全部标签

Java:从同步块(synchronized block)启动新线程时会发生什么?

这里的第一个问题:这是我不知道的Java中一个非常简短但基本的东西......在下面的例子中,run()方法是否以某种方式执行了somemethod()获得的锁?publicsynchronizedvoidsomemethod(){Threadt=newThread(newRunnable(){voidrun(){... 最佳答案 没有。run()在其自己的上下文中同步启动。它不持有任何锁。如果是这样,您要么会遇到死锁,要么会违反规定在任何给定时间只有一个线程可以持有对象锁的规范。如果run()对同一个对象再次调用somemetho

java - 哈希表:为什么get方法是同步的?

我知道Hashtable是同步的,但为什么它的get()方法是同步的?难道只有读方法吗? 最佳答案 如果读取不同步,则可以在读取执行期间修改哈希表。可以添加新元素,底层数组可能变得太小,可以用更大的数组替换等。如果没有顺序执行,很难处理这些情况。但是,即使get不会在Hashtable被另一个线程修改时崩溃,synchronized关键字还有另一个重要方面,即缓存同步。让我们使用一个简化的例子:classFlag{boolvalue;boolget(){returnvalue;}//WARNING:notsynchronizedsy

java - 同步语句的可重入同步行为

我在一个java类中有两个方法,它们都有一个使用同一对象进行同步的代码块。据我了解,在JAVA同步方案中,线程获取的锁是可重入的。有了这个,我可以肯定地说下面的代码在所有情况下都不会引起任何问题吗?publicclassSomeclass{privatestaticfinalObjectLCK_OBJ=newObject();//.....publcvoidmethod1(){//somecode....synchronized(LCK_OBJ){//somesychronizedcode.method2(..);}//somemorecode....}protectedstaticf

java - 如何使用同步锁定整个类的方法?

我知道当你想锁定方法只由一个线程执行时,你可以用synchronized关键字声明它。关于类呢,如何在一个线程时提供对整个类对象的锁正在该类的实例上执行一些代码?换句话说,当一个线程正在一个对象上执行一个方法时,其他线程不应该即使在同一类的不同实例上也允许执行相同的方法。 最佳答案 您在特定对象上进行同步,可以是某个指定的静态锁对象,也可以是类对象(当静态方法被声明为同步时会发生这种情况):classX{privatestaticfinalObjectlock=newObject();publicvoidoneAtATime(){s

java - 线程1在java同步方法1中执行,线程2是否可以在java同步方法2中执行?

想知道是否有人可以帮我解决这个问题。(学生)假设我们有两个线程,“Thread1”和“Thread2”。如果Thread1在方法1中执行,那么Thread2是否可以在方法2中执行?voidmethod1(){synchronized(this){}}voidmethod2(){synchronized(this){}}我要么认为是的,Thread2可以进入,因为“this”只是该方法的实例,或者不能,因为“this”是该类的实例并且Thread1持有它。 最佳答案 没有与特定方法关联的监视器-有与对象关联的监视器。因此,如果您尝试在

java - 遍历集合时如何防止嵌套同步块(synchronized block)

在多线程Java应用程序中,我需要遍历一组对象。由于集合和对象都可能在我迭代它们时被另一个线程修改,所以我需要使用同步。然而,不推荐使用嵌套的同步块(synchronizedblock),因为它们可能会导致死锁。我该如何解决这个问题?CollectiondataCollection=something.getDataCollection();synchronized(dataCollection){for(finalDatadata:dataCollection){synchronized(data){data.doSomething();//doSomething()changeso

【一文看懂 ES 核心】存储&查询&集群

一文看懂ES核心Elasticsearch作为一个搜索引擎,其可以提供高效的搜索匹配数据的能力,对于这类工具了解其运行原理其实是有一套功法的。聊存储,ES是如何存储数据的?聊方法,ES是如何进行搜索匹配的?聊集群,ES的最佳部署方案?集群如何协作?聊使用,在代码中如何使用?ES的一些概念性名称先解释一些概念性名词便于后续的快速理解index索引index相当于ES的数据表,我们主要建立的就是index索引文件,搜索也是基于索引来进行,建立的索引文件会存于磁盘倒排索引为什么叫“倒排”是因为一般的索引是通过下标找数据,而ES为了做分词搜索匹配是通过词来匹配找对应数据的下标,其实我觉得不如叫他“分词

ES特殊字符查询

背景项目使用ES做搜索引擎,大家都知道query_string这个API是支持lucene语法的,所以我们使用这个API支持用户个性化的搜索。项目上线后,用户搜索发现特殊字符无法搜索到而且也无法高亮。原因与解决因为我们的index没有指定分词器所以默认使用的是standard分词器。standard分词器会根据特殊字符或者空格将字符串进行切割,分成一个个词进行存储,那么来看一下standard分词器会把带有特殊字符的字符串解析成哪些词进行存储呢?GET_analyze{"analyzer":"standard","text":["A2654|10|09|022"]}非常明显, 在经过stand

java - 访问/写入 boolean 对象是否需要同步

这似乎是一个非常愚蠢的问题。考虑一下:我有一个带有getter和setter的简单boolean对象。现在,这两种方法都非常频繁地从许多线程中调用。我需要同步这个boolean值吗?boolean赋值也是原子操作吗?[更新]:我已经知道AtomicBoolean。我已经有很多不同的解决方案,但我专门为上述2个问题寻找答案和答案的理由。 最佳答案 不,boolean访问不是原子的(在机器代码级别上),尽管它确实“在Java中只需要1个操作”。因此,是的,您确实需要同步boolean值。请参阅thispresentation的幻灯片4-

java - 静态同步函数如何工作?

这个问题在这里已经有了答案:Javasynchronizedstaticmethods:lockonobjectorclass(8个答案)关闭9年前。当一个Java成员需要线程安全时,我们喜欢下面的做法:publicsynchronizedvoidfunc(){...}此语法等同于:publicvoidfunc(){synchronized(this){....}}也就是说,它实际上使用this来获取锁。我的问题是,如果我使用synchronized和static方法,如下所示:classAA{privateAA(){}publicstaticsynchronizedAAgetInst