草庐IT

javascript - "Isolate"在V8中的作用是什么?怎么可能单独制作 "Isolate"呢?

coder 2025-03-15 原文

到目前为止我发现的“隔离”的解释。

实验#1:http://izs.me/v8-docs/classv8_1_1Isolate.html

“Isolate 表示 V8 引擎的一个孤立实例。 V8 分离株具有完全独立的状态。来自一个隔离区的对象不得用于其他隔离区。当 V8 被初始化时,一个默认的 isolate 被隐式地创建和输入。嵌入器可以创建额外的隔离并在多个线程中并行使用它们。在任何给定时间,最多只能有一个线程进入隔离区。 Locker/Unlocker API 可用于同步。”

实验#2:https://developers.google.com/v8/get_started

“隔离是一个具有自己堆的 VM 实例。”

好的,我明白了。 “隔离”是一个可以单独运行的隔离线程。以下是我的问题。

  1. 它看起来对我来说只是线程,只是它有自己的堆。有什么区别吗?

  2. 我认为“隔离”可以用于实现并发 GC。上面的定义说每个“Isolate”不能用于其他“Isolate”。但是并发 GC 应该检查(或标记)主(或其他)线程(或隔离)的事件对象。怎么可能?

  3. 怎么可能保护自己的对象? “隔离”是一个线程而不是一个进程。所以其他线程如果知道地址就可以访问该线程的对象。怎么保护呢?而且我无法理解自己堆的含义。因为如果其他线程知道地址,它可以被其他线程访问。普通线程可以在内存空间中拥有它们的堆。由于堆的地址空间并没有完全分开,但是如果一个线程 malloc 一 block 内存,除非其他线程知道地址,否则其他线程如何使用它?每个线程只 malloc 自己的堆空间和“隔离”有自己的堆空间有什么区别?

我的问题可以很容易地概括为“Isolate”的作用是什么,怎么可能有自己的堆空间,为什么要有自己的堆。

如果有人分享一些“Isolate”的好文档,那将非常有帮助。 感谢阅读。

---- 把问题说清楚---- 我的问题的关键是 问:是什么让谷歌在 V8 中实现隔离? isolate 有什么好处,什么是在 V8 中使用 isolate 的好例子?他们(隔离)并发执行什么?

最佳答案

  1. It looks like just thread for me, except that it has its own heap. is there any difference?

它们是正交的,一个线程可以同时执行多个isolate,而一个isolate一次只能被一个线程执行。当然,一个 isolate 可以在不同的时间由不同的线程执行,但这可能并不常见。一个 isolate 只是 JavaScript VM 的一个实例,它只有自己的 JavaScript 堆,正常的进程堆仍然在进程中正常共享。

  1. I think "Isolate" can be used for implementing concurrent GC. The definition above says that each "Isolate" cannot be used in other "Isolate". But concurrent GC should check(or mark) the main(or other) thread(or Isolate)'s live objects. How can it be possible?

Mark&Sweep GC 中的非压缩扫描操作可以从另一个线程并发执行。其他 GC 操作,如 compacting sweep、scavenge、marking 只能在 JS 不在 isolate 中执行时执行。

  1. How can it be possible to protect their own objects? "Isolate" is a thread not a process. So other thread can access that thread's object if it knows the address. How could protect it? And I cannot understand the meaning of own heap. Because it can be accessed by other thread if other thread knows the address. And normal thread can have their heap in memory space. Since address space of heap is not seperated exactly but if one thread malloc a memory, how could other thread use it unless others know the address? What's the difference each thread just malloc their own heap space and "Isolate" have its own heap space?

好吧,你不知道地址,也不可能让它坚持使用 V8 API。即使您可以获得地址,使用该地址也不安全,因为 V8 不断地在其堆中移动内容。 malloc 不会返回指向某个 isolate 的 js 堆的地址,因为显然该内存已被 isolate 分配。

关于javascript - "Isolate"在V8中的作用是什么?怎么可能单独制作 "Isolate"呢?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29299397/

有关javascript - "Isolate"在V8中的作用是什么?怎么可能单独制作 "Isolate"呢?的更多相关文章

  1. ruby - 如何从 ruby​​ 中的字符串运行任意对象方法? - 2

    总的来说,我对ruby​​还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用

  2. ruby - 为什么我可以在 Ruby 中使用 Object#send 访问私有(private)/ protected 方法? - 2

    类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc

  3. ruby - 其他文件中的 Rake 任务 - 2

    我试图在一个项目中使用rake,如果我把所有东西都放到Rakefile中,它会很大并且很难读取/找到东西,所以我试着将每个命名空间放在lib/rake中它自己的文件中,我添加了这个到我的rake文件的顶部:Dir['#{File.dirname(__FILE__)}/lib/rake/*.rake'].map{|f|requiref}它加载文件没问题,但没有任务。我现在只有一个.rake文件作为测试,名为“servers.rake”,它看起来像这样:namespace:serverdotask:testdoputs"test"endend所以当我运行rakeserver:testid时

  4. ruby-on-rails - Ruby net/ldap 模块中的内存泄漏 - 2

    作为我的Rails应用程序的一部分,我编写了一个小导入程序,它从我们的LDAP系统中吸取数据并将其塞入一个用户表中。不幸的是,与LDAP相关的代码在遍历我们的32K用户时泄漏了大量内存,我一直无法弄清楚如何解决这个问题。这个问题似乎在某种程度上与LDAP库有关,因为当我删除对LDAP内容的调用时,内存使用情况会很好地稳定下来。此外,不断增加的对象是Net::BER::BerIdentifiedString和Net::BER::BerIdentifiedArray,它们都是LDAP库的一部分。当我运行导入时,内存使用量最终达到超过1GB的峰值。如果问题存在,我需要找到一些方法来更正我的代

  5. ruby-on-rails - rails : "missing partial" when calling 'render' in RSpec test - 2

    我正在尝试测试是否存在表单。我是Rails新手。我的new.html.erb_spec.rb文件的内容是:require'spec_helper'describe"messages/new.html.erb"doit"shouldrendertheform"dorender'/messages/new.html.erb'reponse.shouldhave_form_putting_to(@message)with_submit_buttonendendView本身,new.html.erb,有代码:当我运行rspec时,它失败了:1)messages/new.html.erbshou

  6. ruby-on-rails - 由于 "wkhtmltopdf",PDFKIT 显然无法正常工作 - 2

    我在从html页面生成PDF时遇到问题。我正在使用PDFkit。在安装它的过程中,我注意到我需要wkhtmltopdf。所以我也安装了它。我做了PDFkit的文档所说的一切......现在我在尝试加载PDF时遇到了这个错误。这里是错误:commandfailed:"/usr/local/bin/wkhtmltopdf""--margin-right""0.75in""--page-size""Letter""--margin-top""0.75in""--margin-bottom""0.75in""--encoding""UTF-8""--margin-left""0.75in""-

  7. ruby-on-rails - Rails 3 中的多个路由文件 - 2

    Rails2.3可以选择随时使用RouteSet#add_configuration_file添加更多路由。是否可以在Rails3项目中做同样的事情? 最佳答案 在config/application.rb中:config.paths.config.routes在Rails3.2(也可能是Rails3.1)中,使用:config.paths["config/routes"] 关于ruby-on-rails-Rails3中的多个路由文件,我们在StackOverflow上找到一个类似的问题

  8. ruby-on-rails - Rails - 子类化模型的设计模式是什么? - 2

    我有一个模型:classItem项目有一个属性“商店”基于存储的值,我希望Item对象对特定方法具有不同的行为。Rails中是否有针对此的通用设计模式?如果方法中没有大的if-else语句,这是如何干净利落地完成的? 最佳答案 通常通过Single-TableInheritance. 关于ruby-on-rails-Rails-子类化模型的设计模式是什么?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.co

  9. ruby - 如何以所有可能的方式将字符串拆分为长度最多为 3 的连续子字符串? - 2

    我试图获取一个长度在1到10之间的字符串,并输出将字符串分解为大小为1、2或3的连续子字符串的所有可能方式。例如:输入:123456将整数分割成单个字符,然后继续查找组合。该代码将返回以下所有数组。[1,2,3,4,5,6][12,3,4,5,6][1,23,4,5,6][1,2,34,5,6][1,2,3,45,6][1,2,3,4,56][12,34,5,6][12,3,45,6][12,3,4,56][1,23,45,6][1,2,34,56][1,23,4,56][12,34,56][123,4,5,6][1,234,5,6][1,2,345,6][1,2,3,456][123

  10. ruby - 什么是填充的 Base64 编码字符串以及如何在 ruby​​ 中生成它们? - 2

    我正在使用的第三方API的文档状态:"[O]urAPIonlyacceptspaddedBase64encodedstrings."什么是“填充的Base64编码字符串”以及如何在Ruby中生成它们。下面的代码是我第一次尝试创建转换为Base64的JSON格式数据。xa=Base64.encode64(a.to_json) 最佳答案 他们说的padding其实就是Base64本身的一部分。它是末尾的“=”和“==”。Base64将3个字节的数据包编码为4个编码字符。所以如果你的输入数据有长度n和n%3=1=>"=="末尾用于填充n%

随机推荐