首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >DetoxRuntimeError: NSInvalidArgumentException +[UIWindowScene _keyWindowScene]:无法识别的选择器发送到类0x12dd58db0

DetoxRuntimeError: NSInvalidArgumentException +[UIWindowScene _keyWindowScene]:无法识别的选择器发送到类0x12dd58db0
EN

Stack Overflow用户
提问于 2021-09-28 02:11:58
回答 1查看 230关注 0票数 0

我已经安装了-g detox-clidetox --save-dev (在项目根目录中),我可以构建应用程序,但当我尝试运行它时,我总是收到这个错误。我检查了执行情况,文本元素正在显示,但没有任何功能(toBeVisible、swipe、tap等)成功了。有人知道会是什么吗?谢谢。尽管有文字描述,但这不是登录流程,它只是在机载屏幕上滑动而已。

代码语言:javascript
运行
AI代码解释
复制
Login flow › should be able to login

    DetoxRuntimeError: The pending request #2 ("invoke") has been rejected due to the following error:

    The app has crashed, see the details below:

    Exception was thrown:
    NSInvalidArgumentException
    +[UIWindowScene _keyWindowScene]: unrecognized selector sent to class 0x12f6eedb0
    (
        0   CoreFoundation                      0x000000010f2984a4 __exceptionPreprocess + 226
        1   libobjc.A.dylib                     0x000000010bf3fbe7 objc_exception_throw + 48
        2   CoreFoundation                      0x000000010f2a703a __CFExceptionProem + 0
        3   CoreFoundation                      0x000000010f29c9bc ___forwarding___ + 1433
        4   CoreFoundation                      0x000000010f29eae8 _CF_forwarding_prep_0 + 120
        5   Detox                               0x000000010bf9aa12 +[UIWindow(DetoxUtils) dtx_allKeyWindowSceneWindows] + 43
        6   Detox                               0x000000010bf9e7d1 +[UIView(DetoxMatchers) dtx_findViewsInKeySceneWindowsPassingPredicate:] + 56
        7   Detox                               0x000000010bfbb853 Detox.Element.(views in _14E24C92C1353FEA1FC68E698CB917EF).getter : Swift.Array<__C.NSObject> + 211
        8   Detox                               0x000000010bfbbba1 Detox.Element.(view in _14E24C92C1353FEA1FC68E698CB917EF).getter : __C.NSObject + 49
        9   Detox                               0x000000010bfbd4e7 Detox.Element.isVisible() throws -> Swift.Bool + 39
        10  Detox                               0x000000010bfb5005 Detox.ToBeVisibleExpectation._evaluate() -> () + 101
        11  Detox                               0x000000010bfb4ae5 closure #1 () -> () in Detox.Expectation.evaluate(completionHandler: (Swift.Optional<Swift.Error>) -> ()) -> () + 101
        12  Detox                               0x000000010bfafc8c reabstraction thunk helper from @callee_guaranteed () -> () to @escaping @callee_guaranteed () -> () + 12
        13  Detox                               0x000000010bfad8ae reabstraction thunk helper from @escaping @callee_guaranteed () -> () to @escaping @callee_unowned @convention(block) () -> () + 14
        14  Detox                               0x000000010bfa67fe +[DTXAssertionHandler try:error:] + 47
        15  Detox                               0x000000010bfb9e0c function signature specialization <Arg[1] = Dead, Arg[2] = Owned To Guaranteed, Arg[3] = Owned To Guaranteed> of function signature specialization <Arg[1] = [Closure Propagated : closure #1 (Swift.Optional<Swift.Dictionary<Swift.String, Any>>, Swift.Optional<Swift.Error>) -> () in closure #2 () -> () in Detox.DetoxManager.webSocket(_: Detox.WebSocket, didReceiveAction: Swift.String, params: Swift.Dictionary<Swift.String, Any>, messageId: __C.NSNumber) -> (), Argument Types : [Detox.DetoxManager__C.NSNumber]> of static Detox.InvocationManager.invoke(dictionaryRepresentation: Swift.Dictionary<Swift.String, Any>, completionHandler: (Swift.Optional<Swift.Dictionary<Swift.String, Any>>, Swift.Optional<Swift.Error>) -> ()) -> () + 1852
        16  Detox                               0x000000010bfd3f30 partial apply forwarder for closure #2 () -> () in Detox.DetoxManager.webSocket(_: Detox.WebSocket, didReceiveAction: Swift.String, params: Swift.Dictionary<Swift.String, Any>, messageId: __C.NSNumber) -> () + 64
        17  Detox                               0x000000010bfad8ae reabstraction thunk helper from @escaping @callee_guaranteed () -> () to @escaping @callee_unowned @convention(block) () -> () + 14
        18  DetoxSync                           0x000000014367260d __36+[DTXSyncManager _tryIdleBlocksNow:]_block_invoke.132 + 184
        19  libdispatch.dylib                   0x0000000111724a82 _dispatch_call_block_and_release + 12
        20  libdispatch.dylib                   0x0000000111725c89 _dispatch_client_callout + 8
        21  libdispatch.dylib                   0x00000001117330a8 _dispatch_main_queue_callback_4CF + 1073
        22  CoreFoundation                      0x000000010f206125 __CFRUNLOOP_IS_SERVICING_THE_MAIN_DISPATCH_QUEUE__ + 9
        23  CoreFoundation                      0x000000010f200982 __CFRunLoopRun + 2772
        24  CoreFoundation                      0x000000010f1ff9cb CFRunLoopRunSpecific + 567
        25  GraphicsServices                    0x000000011546fcd3 GSEventRunModal + 139
        26  UIKitCore                           0x000000012e7ca457 -[UIApplication _run] + 928
        27  DetoxSync                           0x000000014366e2fd __detox_sync_UIApplication_run + 362
        28  UIKitCore                           0x000000012e7ceebf UIApplicationMain + 101
        29  Lykon                               0x00000001025825c0 main + 80
        30  dyld                                0x000000010ba4ae1e start_sim + 10
        31  ???                                 0x0000000000000001 0x0 + 1
    )

      11 |
      12 |   it('should be able to login', async () => {
    > 13 |     await expect(element(by.text('Want to become healthier?'))).toBeVisible();
         |                                                                 ^
      14 |     await element(by.text('Want to become healthier?')).swipe('left');
      15 |     await expect(element(by.text('Do like Ina, age 33'))).toBeVisible();
      16 |     await element(by.text('Do like Ina, age 33')).swipe('left');

      at _callee3$ (firstTest.e2e.js:13:65)
      at tryCatch (../node_modules/regenerator-runtime/runtime.js:63:40)
      at Generator.invoke [as _invoke] (../node_modules/regenerator-runtime/runtime.js:294:22)
      at Generator.next (../node_modules/regenerator-runtime/runtime.js:119:21)
      at tryCatch (../node_modules/regenerator-runtime/runtime.js:63:40)
      at invoke (../node_modules/regenerator-runtime/runtime.js:155:20)
      at ../node_modules/regenerator-runtime/runtime.js:190:11

detox[29661] ERROR: [cli.js] Command failed: jest --config e2e/config.json --testNamePattern '^((?!:android:).)*$' --maxWorkers 1 e2e

➜  mobile-app git:(detox-config-new) ✗ detox test -c ios.sim.release
detox[29776] INFO:  [test.js] DETOX_CONFIGURATION="ios.sim.release" DETOX_REPORT_SPECS=true DETOX_START_TIMESTAMP=1632822349209 DETOX_USE_CUSTOM_LOGGER=true jest --config e2e/config.json --testNamePattern '^((?!:android:).)*$' --maxWorkers 1 e2e
detox[29777] INFO:  Login flow is assigned to 7575A670-2BDE-49EF-ADED-07AD59A1E43A iPhone 12
detox[29777] INFO:  [AppleSimUtils.js] com.lykon.app launched. To watch simulator logs, run:
        /usr/bin/xcrun simctl spawn 7575A670-2BDE-49EF-ADED-07AD59A1E43A log stream --level debug --style compact --predicate 'process == "Lykon"'
detox[29777] INFO:  Login flow: should be able to login
detox[29777] INFO:  Login flow: should be able to login [FAIL]

 FAIL  e2e/firstTest.e2e.js (21.925 s)
  Login flow
    ✕ should be able to login (12693 ms)

  ● Login flow › should be able to login

    DetoxRuntimeError: The pending request #2 ("invoke") has been rejected due to the following error:

    The app has crashed, see the details below:

    Exception was thrown:
    NSInvalidArgumentException
    +[UIWindowScene _keyWindowScene]: unrecognized selector sent to class 0x12dd58db0
    (
        0   CoreFoundation                      0x000000010d9024a4 __exceptionPreprocess + 226
        1   libobjc.A.dylib                     0x000000010a5a9be7 objc_exception_throw + 48
        2   CoreFoundation                      0x000000010d91103a __CFExceptionProem + 0
        3   CoreFoundation                      0x000000010d9069bc ___forwarding___ + 1433
        4   CoreFoundation                      0x000000010d908ae8 _CF_forwarding_prep_0 + 120
        5   Detox                               0x000000010a604a12 +[UIWindow(DetoxUtils) dtx_allKeyWindowSceneWindows] + 43
        6   Detox                               0x000000010a6087d1 +[UIView(DetoxMatchers) dtx_findViewsInKeySceneWindowsPassingPredicate:] + 56
        7   Detox                               0x000000010a625853 Detox.Element.(views in _14E24C92C1353FEA1FC68E698CB917EF).getter : Swift.Array<__C.NSObject> + 211
        8   Detox                               0x000000010a625ba1 Detox.Element.(view in _14E24C92C1353FEA1FC68E698CB917EF).getter : __C.NSObject + 49
        9   Detox                               0x000000010a6185b0 Detox.SwipeAction.perform(on: Detox.Element) -> Swift.Optional<Swift.Dictionary<Swift.String, Any>> + 1392
        10  Detox                               0x000000010a618709 vtable thunk for Detox.Action.(perform in _04ABBB5C7C570871DB67625EF38728EC)(on: Detox.Element) -> Swift.Optional<Swift.Dictionary<Swift.String, Any>> dispatching to Detox.SwipeAction.perform(on: Detox.Element) -> Swift.Optional<Swift.Dictionary<Swift.String, Any>> + 9
        11  Detox                               0x000000010a6154ef Detox.Action.(perform in _04ABBB5C7C570871DB67625EF38728EC)(on: Detox.Element, completionHandler: (Swift.Optional<Swift.Dictionary<Swift.String, Any>>, Swift.Optional<Swift.Error>) -> ()) -> () + 31
        12  Detox                               0x000000010a61ad6a partial apply forwarder for closure #1 () -> () in Detox.Action.perform(completionHandler: (Swift.Optional<Swift.Dictionary<Swift.String, Any>>, Swift.Optional<Swift.Error>) -> ()) -> () + 42
        13  Detox                               0x000000010a61adb1 partial apply forwarder for reabstraction thunk helper from @callee_guaranteed () -> () to @escaping @callee_guaranteed () -> () + 17
        14  Detox                               0x000000010a6178ae reabstraction thunk helper from @escaping @callee_guaranteed () -> () to @escaping @callee_unowned @convention(block) () -> () + 14
        15  Detox                               0x000000010a6107fe +[DTXAssertionHandler try:error:] + 47
        16  Detox                               0x000000010a6155fe Detox.Action.perform(completionHandler: (Swift.Optional<Swift.Dictionary<Swift.String, Any>>, Swift.Optional<Swift.Error>) -> ()) -> () + 238
        17  Detox                               0x000000010a623aa4 function signature specialization <Arg[1] = Dead, Arg[2] = Owned To Guaranteed, Arg[3] = Owned To Guaranteed> of function signature specialization <Arg[1] = [Closure Propagated : closure #1 (Swift.Optional<Swift.Dictionary<Swift.String, Any>>, Swift.Optional<Swift.Error>) -> () in closure #2 () -> () in Detox.DetoxManager.webSocket(_: Detox.WebSocket, didReceiveAction: Swift.String, params: Swift.Dictionary<Swift.String, Any>, messageId: __C.NSNumber) -> (), Argument Types : [Detox.DetoxManager__C.NSNumber]> of static Detox.InvocationManager.invoke(dictionaryRepresentation: Swift.Dictionary<Swift.String, Any>, completionHandler: (Swift.Optional<Swift.Dictionary<Swift.String, Any>>, Swift.Optional<Swift.Error>) -> ()) -> () + 980
        18  Detox                               0x000000010a63df30 partial apply forwarder for closure #2 () -> () in Detox.DetoxManager.webSocket(_: Detox.WebSocket, didReceiveAction: Swift.String, params: Swift.Dictionary<Swift.String, Any>, messageId: __C.NSNumber) -> () + 64
        19  Detox                               0x000000010a6178ae reabstraction thunk helper from @escaping @callee_guaranteed () -> () to @escaping @callee_unowned @convention(block) () -> () + 14
        20  DetoxSync                           0x0000000141cdc60d __36+[DTXSyncManager _tryIdleBlocksNow:]_block_invoke.132 + 184
        21  libdispatch.dylib                   0x000000010fd8ea82 _dispatch_call_block_and_release + 12
        22  libdispatch.dylib                   0x000000010fd8fc89 _dispatch_client_callout + 8
        23  libdispatch.dylib                   0x000000010fd9d0a8 _dispatch_main_queue_callback_4CF + 1073
        24  CoreFoundation                      0x000000010d870125 __CFRUNLOOP_IS_SERVICING_THE_MAIN_DISPATCH_QUEUE__ + 9
        25  CoreFoundation                      0x000000010d86a982 __CFRunLoopRun + 2772
        26  CoreFoundation                      0x000000010d8699cb CFRunLoopRunSpecific + 567
        27  GraphicsServices                    0x0000000113ad9cd3 GSEventRunModal + 139
        28  UIKitCore                           0x000000012ce34457 -[UIApplication _run] + 928
        29  DetoxSync                           0x0000000141cd82fd __detox_sync_UIApplication_run + 362
        30  UIKitCore                           0x000000012ce38ebf UIApplicationMain + 101
        31  Lykon                               0x0000000100bec5c0 main + 80
        32  dyld                                0x000000010a0b4e1e start_sim + 10
        33  ???                                 0x0000000000000001 0x0 + 1
    )

      12 |   it('should be able to login', async () => {
      13 |     //await expect(element(by.text('Want to become healthier?'))).toBeVisible();
    > 14 |     await element(by.text('Want to become healthier?')).swipe('left');
         |                                                         ^
      15 |     await expect(element(by.text('Do like Ina, age 33'))).toBeVisible();
      16 |     await element(by.text('Do like Ina, age 33')).swipe('left');
      17 |     await expect(element(by.text('Stop the second guessing'))).toBeVisible();

      at _callee3$ (firstTest.e2e.js:14:57)
      at tryCatch (../node_modules/regenerator-runtime/runtime.js:63:40)
      at Generator.invoke [as _invoke] (../node_modules/regenerator-runtime/runtime.js:294:22)
      at Generator.next (../node_modules/regenerator-runtime/runtime.js:119:21)
      at tryCatch (../node_modules/regenerator-runtime/runtime.js:63:40)
      at invoke (../node_modules/regenerator-runtime/runtime.js:155:20)
      at ../node_modules/regenerator-runtime/runtime.js:190:11

detox[29776] ERROR: [cli.js] Command failed: jest --config e2e/config.json --testNamePattern '^((?!:android:).)*$' --maxWorkers 1 e2e

这是我第一次在Stack Overflow上问问题,我有点迷茫,不知道我应该提供什么信息。所以,如果你需要更多的信息,我很感谢你问我。谢谢。

e2e/config.json:

代码语言:javascript
运行
AI代码解释
复制
{
  "testEnvironment": "./environment",
  "testRunner": "jest-circus/runner",
  "testTimeout": 120000,
  "testRegex": "\\.e2e\\.js$",
  "reporters": ["detox/runners/jest/streamlineReporter"],
  "verbose": true
}

e2e/environment.js .js

代码语言:javascript
运行
AI代码解释
复制
const {
  DetoxCircusEnvironment,
  SpecReporter,
  WorkerAssignReporter
} = require('detox/runners/jest-circus');

class CustomDetoxEnvironment extends DetoxCircusEnvironment {
  constructor(config, context) {
    super(config, context);

    // Can be safely removed, if you are content with the default value (=300000ms)
    this.initTimeout = 300000;

    // This takes care of generating status logs on a per-spec basis. By default, Jest only reports at file-level.
    // This is strictly optional.
    this.registerListeners({
      SpecReporter,
      WorkerAssignReporter
    });
  }
}

module.exports = CustomDetoxEnvironment;
EN

回答 1

Stack Overflow用户

发布于 2021-10-05 07:29:04

在这篇PR https://github.com/wix/Detox/issues/2895升级到"detox": "^18.22.1"中讨论了iOS 15的问题时,解毒已经帮我解决了这个问题

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/69359825

复制
相关文章
Amazon对接选EDI还是API
亚马逊为供应商提供EDI与API方式来进行数据的对接,供应商可通过上述两种方式与亚马逊平台进行集成,从而实现点对点自动接收订单,回传发票、ASN。
知行软件EDI
2022/05/25
7290
Amazon对接选EDI还是API
8个woocommerce支付网关插件推荐
当然您以前听说过WooCommerce吗?这是用WordPress建立在线商店的最简单方法之一。WooCommerce允许网站所有者添加产品,数字商品,甚至订​​阅(取决于您已安装的WooCommerce扩展)。但是,对于WooCommerce包含的所有强大功能,仅内置了一些默认付款选项。幸运的是,您可以添加大量免费的高级WooCommerce付款网关插件,为客户提供新的结帐选项。
Hoan外贸建站
2020/12/03
6.9K0
Serverless 时代,这才是Web应用开发正确的打开方式 | Q推荐
如同 iPhone 当年颠覆了诺基亚,Serverless 的出现也带来了一种全新的、颠覆式的云开发架构模式。在 Serverless 出现前,开发者们根本无法想象几分钟就能快速部署一个 Web 应用上线。近日,亚马逊云科技 Tech Talk 特别邀请了资深无服务器技术专家孙华带来分享《 如何高效、极简构造无服务器 Web 应用》。孙华以 Amazon Lambda 的视角介绍了无服务器 Web 应用的构造方式,并讲述了如何利用最新发布的 Lambda Function URLs 和 Lambda Adapter 进一步简化无服务器 Web 应用的开发和调试并且实现 Web 应用在 Lambda,Fargate 和 EC2 等计算平台之间平滑迁移。
深度学习与Python
2022/06/13
3.6K0
Serverless 时代,这才是Web应用开发正确的打开方式 | Q推荐
Woocommerce Trends 2020
Top Woocommerce Trends To Follow In 2020. If you have an online store and missed out on the last annual Woosesh virtual conference held a few months ago, then you’re short of information in updating yourself with the latest trends of Woocommerce.
用户4822892
2019/12/10
6030
Woocommerce Trends 2020
说说 WooCommerce 插件
玩儿过WordPress的估计都听说过WooCommerce插件吧?明月其实很早的时候就接触和体验过WooCommerce插件了,严格意义上来说WooCommerce应该是WordPress平台下开源电子商务解决方案才比较确切些,也就是说WordPress+WooCommerce就是一套电子商务解决方案了,也就是我们俗称的“在线商城”。
明月登楼的博客
2021/04/30
1.9K0
说说 WooCommerce 插件
Amazon DynamoDB 工作原理、API和数据类型介绍
DynamoDB 是 AWS 独有的完全托管的 NoSQL Database。它的思想来源于 Amazon 2007 年发表的一篇论文:Dynamo: Amazon’s Highly Available Key-value Store。在这篇论文里,Amazon 介绍了如何使用 Commodity Hardware 来打造高可用、高弹性的数据存储。想要理解 DynamoDB,首先要理解 Consistent Hashing。Consistent Hashing 的原理如下图所示:
goodspeed
2020/12/25
6K0
如何与亚马逊Amazon供应商平台集成?——EDI or API
亚马逊Amazon供应商平台支持通过EDI和API两种方式进行集成,不禁开始思考到底该选择哪种方式来集成?
知行软件EDI
2021/12/13
1.3K0
如何与亚马逊Amazon供应商平台集成?——EDI or API
woocommerce如何隐藏SKU
  有时我们不想在woocommerce网站前台显示SKU,如下图所示,因为sku一多整个排版可能会乱,那么要如何隐藏sku呢?随ytkah一起来看看
ytkah
2019/12/20
2.2K0
woocommerce如何隐藏SKU
Amazon DynamoDB
DynamoDB 是Amazon最新发布的NoSQL产品,那什么是DynamoDB呢?
阳光岛主
2019/02/19
3.1K0
禁用woocommerce默认样式stylesheet
  用woocommerce建站有时我们不想要它的默认样式,那要如何屏蔽呢?当然ytkah是不会告诉你去注释删除css代码的,默认情况下WooCommerce会嵌入3个样式表,我们可以通过在当前主题的function.php文件中添加以下代码禁用它们,
ytkah
2020/02/13
1.6K0
南桥和北桥
现代 PC 机主板主要使用 2 个超大规模芯片构成的芯片组或芯片集(Chipsets)组成:北桥(Northbridge)芯片和南桥(Southbridge)芯片。北桥芯片用于与 CPU、内存和 AGP 视频接口,这些接口具有很高的传输速率。北桥芯片还起着存储器控制作用,因此Intel 把该芯片标号为 MCH(Memory Controller Hub)芯片。南桥芯片用来管理低、中速的组件,例如,PCI 总线、IDE 硬盘接口、USB 端口等,因此南桥芯片的名称为 ICH(I/O Controller Hub)。之所以用“南、北”桥来分别统称这两个芯片,是由于在 Intel 公司公布的典型 PC 机主板上,它们分别位于主版的下端和上端(即地图上的南部和北部)位置,并起着与 CPU 进行通道桥接的作用。 --by《Linux内核完全注释》
zy010101
2020/08/20
1.7K0
woocommerce模板制作简易教程
  woocommerce是wordpress里比较好用的电商解决方案,但是制作woocommerce模板相对比较复杂,如果想用woocommerce来建一个展示型的网站,不带下单功能,我们可以很快就能把模板设计出来,下面就跟着ytkah一起来学习吧
ytkah
2019/06/24
2.8K0
woocommerce shortcode短代码调用
WooCommerce配备了很多shortcode短代码(简码),可以直接在post帖子和page页面内插入内容,方便展示产品、分类等。比如直接在文章编辑时直接插入[products],或者在php文
ytkah
2023/03/14
11.4K0
woocommerce shortcode短代码调用
woocommerce如何隐藏/显示product meta
  前面我们说了woocommerce如何隐藏SKU,那如果不想显示产品分类category和标签tag呢?我们知道SKU, Category list 和 Tag list在woocommerce产品页中统称为产品product meta,下图红框所示。1、如果想全部隐藏这些meta很简单,在当前主题function.php文件中加入下面的代码即可
ytkah
2019/12/19
3.4K0
woocommerce根据标题获取相关产品
  我们知道woocommerce的相关文章是根据分类category或标签tag来获取的,能不能实现根据标题来调取相关产品呢?get_posts() 函数可以根据库存、价格、自定义项、搜索条件等不同的标准来显示不同的相关产品,如何操作呢?随ytkah一起来看看
ytkah
2019/12/19
1.6K0
Amazon Aurora 深度探索(三)
serena
2017/08/09
3K0
Amazon Aurora 深度探索(三)
WordPress插件WooCommerce任意文件删除漏洞分析
近期,研究人员在WordPress的权限处理机制中发现了一个安全漏洞,而这个漏洞将允许WordPress插件实现提权。其中一个典型例子就是WooCommerce,该插件是目前最热门的一款电子商务插件,并且拥有400万+的安装量。简而言之,这个漏洞将允许商铺管理员删除目标服务器上的特定文件,并接管管理员帐号。
FB客服
2018/12/24
1.7K0
WooCommerce Elementor Addons – 商品页面编辑器插件
TFProduct是用于Elementor Page Builder的WooCommerce插件,帮助您在页面构建器Elementor中显示WooCommerce产品。 它是最灵活的小部件,可让您以网格,轮播,分页方式显示WooCommerce产品,并加载更多布局。它可以显示编号显示产品,最新产品,特色产品,畅销产品,销售产品,最高评分产品,混合订单产品,类别产品。此外,我们还提供了完全免费的Elementor Themesflat附加组件,以及YouTube窗口小部件。您可以完全创建带有完整的页眉页脚滑块,图像框,轮播框和所有Elementor Free小部件的专业视频网站。
小狐狸说事
2022/12/30
2.2K0
WooCommerce Elementor Addons – 商品页面编辑器插件
Amazon Dynamo系统架构
本文参考了网上众多文章,把 Amazon Dynamo 架构汇总成文,为后续源码分析奠定基础。
罗西的思考
2021/02/04
1.5K0
点击加载更多

相似问题

鼠标拖动的OpenGL翻译点

13

C++ OpenGL用鼠标拖动多个对象

14

如何用OpenGL绘制鼠标拖动上的连续点

12

用OpenGL在拖动鼠标上绘制不连续线

11

用C++和OpenGL拖动三维对象

15
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文