Deep Object Compare 123

JavaScript performance comparison

Test case created by Linksku

Preparation code


      
      <script>
Benchmark.prototype.setup = function() {
  // CloudFlare blocks JSON.
  const data = atob(`{"kind":"Listing","data":{"modhash":"lsq0bknqq25cf25f9e324886e0d86497f0260b326d1fbb439a","dist":5,"children":[{"kind":"t3","data":{"approved_at_utc":null,"subreddit":"javascript","selftext":"Post a link to a GitHub repo that you would like to have reviewed, and brace yourself for the comments!\nWhether you're a junior wanting your code sharpened or a senior interested in giving some feedback and have some time to spare, \nthis is the place.\n\n[Named after this comic](https://davidwalsh.name/demo/code-review.png)","author_fullname":"t2_6l4z3","saved":false,"mod_reason_title":null,"gilded":0,"clicked":false,"title":"WTF Wednesday (July 08, 2020)","link_flair_richtext":[],"subreddit_name_prefixed":"r/javascript","hidden":false,"pwls":6,"link_flair_css_class":"wtfwednesday","downs":0,"top_awarded_type":null,"hide_score":false,"name":"t3_hnjqff","quarantine":false,"link_flair_text_color":"dark","upvote_ratio":0.79,"author_flair_background_color":null,"subreddit_type":"public","ups":10,"total_awards_received":0,"media_embed":{},"author_flair_template_id":null,"is_original_content":false,"user_reports":[],"secure_media":null,"is_reddit_media_domain":false,"is_meta":false,"category":null,"secure_media_embed":{},"link_flair_text":"WTF Wednesday","can_mod_post":false,"score":10,"approved_by":null,"author_premium":true,"thumbnail":"","edited":false,"author_flair_css_class":null,"author_flair_richtext":[],"gildings":{},"content_categories":null,"is_self":true,"mod_note":null,"created":1594253056,"link_flair_type":"text","wls":6,"removed_by_category":null,"banned_by":null,"author_flair_type":"text","domain":"self.javascript","allow_live_comments":false,"selftext_html":"&lt;!-- SC_OFF --&gt;&lt;div class=\"md\"&gt;&lt;p&gt;Post a link to a GitHub repo that you would like to have reviewed, and brace yourself for the comments!\nWhether you&amp;#39;re a junior wanting your code sharpened or a senior interested in giving some feedback and have some time to spare, \nthis is the place.&lt;/p&gt;\n\n&lt;p&gt;&lt;a href=\"https://davidwalsh.name/demo/code-review.png\"&gt;Named after this comic&lt;/a&gt;&lt;/p&gt;\n&lt;/div&gt;&lt;!-- SC_ON --&gt;","likes":null,"suggested_sort":null,"banned_at_utc":null,"view_count":null,"archived":false,"no_follow":true,"is_crosspostable":true,"pinned":false,"over_18":false,"all_awardings":[],"awarders":[],"media_only":false,"can_gild":true,"spoiler":false,"locked":false,"author_flair_text":null,"treatment_tags":[],"visited":false,"removed_by":null,"num_reports":null,"distinguished":"moderator","subreddit_id":"t5_2qh30","mod_reason_by":null,"removal_reason":null,"link_flair_background_color":"","id":"hnjqff","is_robot_indexable":true,"report_reasons":null,"author":"AutoModerator","discussion_type":null,"num_comments":3,"send_replies":false,"whitelist_status":"all_ads","contest_mode":false,"mod_reports":[],"author_patreon_flair":false,"author_flair_text_color":null,"permalink":"/r/javascript/comments/hnjqff/wtf_wednesday_july_08_2020/","parent_whitelist_status":"all_ads","stickied":true,"url":"https://www.reddit.com/r/javascript/comments/hnjqff/wtf_wednesday_july_08_2020/","subreddit_subscribers":1008603,"created_utc":1594224256,"num_crossposts":0,"media":null,"is_video":false}},{"kind":"t3","data":{"approved_at_utc":null,"subreddit":"javascript","selftext":"Post a link to a GitHub repo that you would like to have reviewed, and brace yourself for the comments!\nWhether you're a junior wanting your code sharpened or a senior interested in giving some feedback and have some time to spare, \nthis is the place.\n\n[Named after this comic](https://davidwalsh.name/demo/code-review.png)","author_fullname":"t2_6l4z3","saved":false,"mod_reason_title":null,"gilded":0,"clicked":false,"title":"WTF Wednesday (July 15, 2020)","link_flair_richtext":[],"subreddit_name_prefixed":"r/javascript","hidden":false,"pwls":6,"link_flair_css_class":"wtfwednesday","downs":0,"top_awarded_type":null,"hide_score":false,"name":"t3_hrqb20","quarantine":false,"link_flair_text_color":"dark","upvote_ratio":1,"author_flair_background_color":null,"subreddit_type":"public","ups":1,"total_awards_received":0,"media_embed":{},"author_flair_template_id":null,"is_original_content":false,"user_reports":[],"secure_media":null,"is_reddit_media_domain":false,"is_meta":false,"category":null,"secure_media_embed":{},"link_flair_text":"WTF Wednesday","can_mod_post":false,"score":1,"approved_by":null,"author_premium":true,"thumbnail":"","edited":false,"author_flair_css_class":null,"author_flair_richtext":[],"gildings":{},"content_categories":null,"is_self":true,"mod_note":null,"created":1594857868,"link_flair_type":"text","wls":6,"removed_by_category":null,"banned_by":null,"author_flair_type":"text","domain":"self.javascript","allow_live_comments":false,"selftext_html":"&lt;!-- SC_OFF --&gt;&lt;div class=\"md\"&gt;&lt;p&gt;Post a link to a GitHub repo that you would like to have reviewed, and brace yourself for the comments!\nWhether you&amp;#39;re a junior wanting your code sharpened or a senior interested in giving some feedback and have some time to spare, \nthis is the place.&lt;/p&gt;\n\n&lt;p&gt;&lt;a href=\"https://davidwalsh.name/demo/code-review.png\"&gt;Named after this comic&lt;/a&gt;&lt;/p&gt;\n&lt;/div&gt;&lt;!-- SC_ON --&gt;","likes":null,"suggested_sort":null,"banned_at_utc":null,"view_count":null,"archived":false,"no_follow":true,"is_crosspostable":true,"pinned":false,"over_18":false,"all_awardings":[],"awarders":[],"media_only":false,"can_gild":true,"spoiler":false,"locked":false,"author_flair_text":null,"treatment_tags":[],"visited":false,"removed_by":null,"num_reports":null,"distinguished":"moderator","subreddit_id":"t5_2qh30","mod_reason_by":null,"removal_reason":null,"link_flair_background_color":"","id":"hrqb20","is_robot_indexable":true,"report_reasons":null,"author":"AutoModerator","discussion_type":null,"num_comments":0,"send_replies":false,"whitelist_status":"all_ads","contest_mode":false,"mod_reports":[],"author_patreon_flair":false,"author_flair_text_color":null,"permalink":"/r/javascript/comments/hrqb20/wtf_wednesday_july_15_2020/","parent_whitelist_status":"all_ads","stickied":true,"url":"https://www.reddit.com/r/javascript/comments/hrqb20/wtf_wednesday_july_15_2020/","subreddit_subscribers":1008603,"created_utc":1594829068,"num_crossposts":0,"media":null,"is_video":false}},{"kind":"t3","data":{"approved_at_utc":null,"subreddit":"javascript","selftext":"","author_fullname":"t2_16cgbu","saved":false,"mod_reason_title":null,"gilded":0,"clicked":false,"title":"Super Expressive - a Zero-dependency JavaScript Library For Building Regular Expressions in (Almost) Natural Language","link_flair_richtext":[],"subreddit_name_prefixed":"r/javascript","hidden":false,"pwls":6,"link_flair_css_class":null,"downs":0,"top_awarded_type":null,"hide_score":false,"name":"t3_hrlv0w","quarantine":false,"link_flair_text_color":"dark","upvote_ratio":0.98,"author_flair_background_color":null,"subreddit_type":"public","ups":175,"total_awards_received":1,"media_embed":{},"author_flair_template_id":null,"is_original_content":false,"user_reports":[],"secure_media":null,"is_reddit_media_domain":false,"is_meta":false,"category":null,"secure_media_embed":{},"link_flair_text":null,"can_mod_post":false,"score":175,"approved_by":null,"author_premium":false,"thumbnail":"","edited":false,"author_flair_css_class":null,"author_flair_richtext":[],"gildings":{},"content_categories":null,"is_self":false,"mod_note":null,"created":1594841252,"link_flair_type":"text","wls":6,"removed_by_category":null,"banned_by":null,"author_flair_type":"text","domain":"github.com","allow_live_comments":false,"selftext_html":null,"likes":null,"suggested_sort":null,"banned_at_utc":null,"url_overridden_by_dest":"https://github.com/francisrstokes/super-expressive","view_count":null,"archived":false,"no_follow":false,"is_crosspostable":true,"pinned":false,"over_18":false,"all_awardings":[{"giver_coin_reward":null,"subreddit_id":null,"is_new":false,"days_of_drip_extension":0,"coin_price":150,"id":"award_f44611f1-b89e-46dc-97fe-892280b13b82","penny_donate":null,"award_sub_type":"GLOBAL","coin_reward":0,"icon_url":"https://i.redd.it/award_images/t5_22cerq/klvxk1wggfd41_Helpful.png","days_of_premium":0,"resized_icons":[{"url":"https://preview.redd.it/award_images/t5_22cerq/klvxk1wggfd41_Helpful.png?width=16&amp;height=16&amp;auto=webp&amp;s=a5662dfbdb402bf67866c050aa76c31c147c2f45","width":16,"height":16},{"url":"https://preview.redd.it/award_images/t5_22cerq/klvxk1wggfd41_Helpful.png?width=32&amp;height=32&amp;auto=webp&amp;s=a6882eb3f380e8e88009789f4d0072e17b8c59f1","width":32,"height":32},{"url":"https://preview.redd.it/award_images/t5_22cerq/klvxk1wggfd41_Helpful.png?width=48&amp;height=48&amp;auto=webp&amp;s=e50064b090879e8a0b55e433f6ee61d5cb5fbe1d","width":48,"height":48},{"url":"https://preview.redd.it/award_images/t5_22cerq/klvxk1wggfd41_Helpful.png?width=64&amp;height=64&amp;auto=webp&amp;s=8e5bb2e76683cb6b161830bcdd9642049d6adc11","width":64,"height":64},{"url":"https://preview.redd.it/award_images/t5_22cerq/klvxk1wggfd41_Helpful.png?width=128&amp;height=128&amp;auto=webp&amp;s=eda4a9246f95f42ee6940cc0ec65306fd20de878","width":128,"height":128}],"icon_width":2048,"static_icon_width":2048,"start_date":null,"is_enabled":true,"description":"Thank you stranger. Shows the award.","end_date":null,"subreddit_coin_reward":0,"count":1,"static_icon_height":2048,"name":"Helpful","resized_static_icons":[{"url":"https://preview.redd.it/award_images/t5_22cerq/klvxk1wggfd41_Helpful.png?width=16&amp;height=16&amp;auto=webp&amp;s=a5662dfbdb402bf67866c050aa76c31c147c2f45","width":16,"height":16},{"url":"https://preview.redd.it/award_images/t5_22cerq/klvxk1wggfd41_Helpful.png?width=32&amp;height=32&amp;auto=webp&amp;s=a6882eb3f380e8e88009789f4d0072e17b8c59f1","width":32,"height":32},{"url":"https://preview.redd.it/award_images/t5_22cerq/klvxk1wggfd41_Helpful.png?width=48&amp;height=48&amp;auto=webp&amp;s=e50064b090879e8a0b55e433f6ee61d5cb5fbe1d","width":48,"height":48},{"url":"https://preview.redd.it/award_images/t5_22cerq/klvxk1wggfd41_Helpful.png?width=64&amp;height=64&amp;auto=webp&amp;s=8e5bb2e76683cb6b161830bcdd9642049d6adc11","width":64,"height":64},{"url":"https://preview.redd.it/award_images/t5_22cerq/klvxk1wggfd41_Helpful.png?width=128&amp;height=128&amp;auto=webp&amp;s=eda4a9246f95f42ee6940cc0ec65306fd20de878","width":128,"height":128}],"icon_format":null,"icon_height":2048,"penny_price":null,"award_type":"global","static_icon_url":"https://i.redd.it/award_images/t5_22cerq/klvxk1wggfd41_Helpful.png"}],"awarders":[],"media_only":false,"can_gild":true,"spoiler":false,"locked":false,"author_flair_text":null,"treatment_tags":[],"visited":false,"removed_by":null,"num_reports":null,"distinguished":null,"subreddit_id":"t5_2qh30","mod_reason_by":null,"removal_reason":null,"link_flair_background_color":"","id":"hrlv0w","is_robot_indexable":true,"report_reasons":null,"author":"FrancisStokes","discussion_type":null,"num_comments":42,"send_replies":true,"whitelist_status":"all_ads","contest_mode":false,"mod_reports":[],"author_patreon_flair":false,"author_flair_text_color":null,"permalink":"/r/javascript/comments/hrlv0w/super_expressive_a_zerodependency_javascript/","parent_whitelist_status":"all_ads","stickied":false,"url":"https://github.com/francisrstokes/super-expressive","subreddit_subscribers":1008603,"created_utc":1594812452,"num_crossposts":0,"media":null,"is_video":false}},{"kind":"t3","data":{"approved_at_utc":null,"subreddit":"javascript","selftext":"","author_fullname":"t2_ne8wzy0","saved":false,"mod_reason_title":null,"gilded":0,"clicked":false,"title":"Moveable Editor Tool 0.18 Release! Drag, Resize, Scale, Rotate, Clip, Group, Snap","link_flair_richtext":[],"subreddit_name_prefixed":"r/javascript","hidden":false,"pwls":6,"link_flair_css_class":null,"downs":0,"top_awarded_type":null,"hide_score":false,"name":"t3_hrg2n0","quarantine":false,"link_flair_text_color":"dark","upvote_ratio":0.98,"author_flair_background_color":null,"subreddit_type":"public","ups":157,"total_awards_received":0,"media_embed":{},"author_flair_template_id":null,"is_original_content":false,"user_reports":[],"secure_media":null,"is_reddit_media_domain":false,"is_meta":false,"category":null,"secure_media_embed":{},"link_flair_text":null,"can_mod_post":false,"score":157,"approved_by":null,"author_premium":false,"thumbnail":"","edited":false,"author_flair_css_class":null,"author_flair_richtext":[],"gildings":{},"content_categories":null,"is_self":false,"mod_note":null,"created":1594811991,"link_flair_type":"text","wls":6,"removed_by_category":null,"banned_by":null,"author_flair_type":"text","domain":"daybrush.com","allow_live_comments":false,"selftext_html":null,"likes":null,"suggested_sort":null,"banned_at_utc":null,"url_overridden_by_dest":"https://daybrush.com/moveable/","view_count":null,"archived":false,"no_follow":false,"is_crosspostable":true,"pinned":false,"over_18":false,"all_awardings":[],"awarders":[],"media_only":false,"can_gild":true,"spoiler":false,"locked":false,"author_flair_text":null,"treatment_tags":[],"visited":false,"removed_by":null,"num_reports":null,"distinguished":null,"subreddit_id":"t5_2qh30","mod_reason_by":null,"removal_reason":null,"link_flair_background_color":"","id":"hrg2n0","is_robot_indexable":true,"report_reasons":null,"author":"daybrush","discussion_type":null,"num_comments":10,"send_replies":true,"whitelist_status":"all_ads","contest_mode":false,"mod_reports":[],"author_patreon_flair":false,"author_flair_text_color":null,"permalink":"/r/javascript/comments/hrg2n0/moveable_editor_tool_018_release_drag_resize/","parent_whitelist_status":"all_ads","stickied":false,"url":"https://daybrush.com/moveable/","subreddit_subscribers":1008603,"created_utc":1594783191,"num_crossposts":1,"media":null,"is_video":false}},{"kind":"t3","data":{"approved_at_utc":null,"subreddit":"javascript","selftext":"","author_fullname":"t2_fc7dj","saved":false,"mod_reason_title":null,"gilded":0,"clicked":false,"title":"Developers can't fix bad management","link_flair_richtext":[],"subreddit_name_prefixed":"r/javascript","hidden":false,"pwls":6,"link_flair_css_class":null,"downs":0,"top_awarded_type":null,"hide_score":false,"name":"t3_hrhpo1","quarantine":false,"link_flair_text_color":"dark","upvote_ratio":0.96,"author_flair_background_color":null,"subreddit_type":"public","ups":82,"total_awards_received":0,"media_embed":{},"author_flair_template_id":null,"is_original_content":false,"user_reports":[],"secure_media":null,"is_reddit_media_domain":false,"is_meta":false,"category":null,"secure_media_embed":{},"link_flair_text":null,"can_mod_post":false,"score":82,"approved_by":null,"author_premium":false,"thumbnail":"","edited":false,"author_flair_css_class":null,"author_flair_richtext":[],"gildings":{},"content_categories":null,"is_self":false,"mod_note":null,"created":1594819232,"link_flair_type":"text","wls":6,"removed_by_category":null,"banned_by":null,"author_flair_type":"text","domain":"iism.org","allow_live_comments":false,"selftext_html":null,"likes":null,"suggested_sort":null,"banned_at_utc":null,"url_overridden_by_dest":"https://iism.org/article/developers-can-t-fix-bad-management-57","view_count":null,"archived":false,"no_follow":false,"is_crosspostable":true,"pinned":false,"over_18":false,"all_awardings":[],"awarders":[],"media_only":false,"can_gild":true,"spoiler":false,"locked":false,"author_flair_text":null,"treatment_tags":[],"visited":false,"removed_by":null,"num_reports":null,"distinguished":null,"subreddit_id":"t5_2qh30","mod_reason_by":null,"removal_reason":null,"link_flair_background_color":"","id":"hrhpo1","is_robot_indexable":true,"report_reasons":null,"author":"jasonbourne1901","discussion_type":null,"num_comments":27,"send_replies":true,"whitelist_status":"all_ads","contest_mode":false,"mod_reports":[],"author_patreon_flair":false,"author_flair_text_color":null,"permalink":"/r/javascript/comments/hrhpo1/developers_cant_fix_bad_management/","parent_whitelist_status":"all_ads","stickied":false,"url":"https://iism.org/article/developers-can-t-fix-bad-management-57","subreddit_subscribers":1008603,"created_utc":1594790432,"num_crossposts":0,"media":null,"is_video":false}}],"after":"t3_hrhpo1","before":null}}`);
  const data1 = JSON.parse(data);
  const data2 = JSON.parse(data);
  
  function equals1(x, y) {
    if (x === y) return true;
  
    if (Array.isArray(x) && Array.isArray(y)) {
      if (x.length !== y.length) return false;
  
      for (let i = 0; i < x.length; i++) {
        if (!equals1(x[i], y[i])) return false;
      }
      return true;
    }
  
    if ((typeof x !== 'object') || (typeof y !== 'object')) return false;
  
    const xKeys = Object.keys(x);
    const yKeys = Object.keys(y);
    if (xKeys.length !== yKeys.length) return false;
    for (const k of xKeys) {
      if (!y.hasOwnProperty(k)) return false;
  
      if (!equals1(x[k], y[k])) return false;
    }
  
    return true;
  }
  
  function equals2(a, b) {
    const stack = [a, b];
    let idx = 2;
    while (idx > 0) {
      const x = stack[idx - 1];
      const y = stack[idx - 2];
      idx -= 2;
  
      if (x === y) continue;
  
      if (Array.isArray(x) && Array.isArray(y)) {
        if (x.length !== y.length) return false;
    
        for (let i = 0; i < x.length; i++) {
          idx += 2;
          if (idx > stack.length) stack.push(x[i], y[i]);
          else {
            stack[idx - 1] = x[i];
            stack[idx - 2] = y[i];
          }
        }
      } else {
        if ((typeof x !== 'object') || (typeof y !== 'object')) return false;
  
        const xKeys = Object.keys(x);
        const yKeys = Object.keys(y);
        if (xKeys.length !== yKeys.length) return false;
        for (const k of xKeys) {
          if (!y.hasOwnProperty(k)) return false;
  
          idx += 2;
          if (idx > stack.length) stack.push(x[k], y[k]);
          else {
            stack[idx - 1] = x[k];
            stack[idx - 2] = y[k];
          }
        }
      }
    }
  
    return true;
  }
  
  function equals3(a, b) {
    const stack = ['k', { k: a }, { k: b }];
    let idx = 3;
    while (idx > 0) {
      const k = stack[idx - 3];
      const x = stack[idx - 2][k];
      const y = stack[idx - 1][k];
      idx -= 3;
  
      if (x === y) continue;
  
      if (Array.isArray(x) && Array.isArray(y)) {
        if (x.length !== y.length) return false;
    
        for (let i = 0; i < x.length; i++) {
          idx += 3;
          if (idx > stack.length) stack.push(i, x, y);
          else {
            stack[idx - 3] = i;
            stack[idx - 2] = x;
            stack[idx - 1] = y;
          }
        }
      } else {
        if ((typeof x !== 'object') || (typeof y !== 'object')) return false;
  
        const xKeys = Object.keys(x);
        const yKeys = Object.keys(y);
        if (xKeys.length !== yKeys.length) return false;
        for (const k2 of xKeys) {
          if (!y.hasOwnProperty(k2)) return false;
  
          idx += 3;
          if (idx > stack.length) stack.push(k2, x, y);
          else {
            stack[idx - 3] = k2;
            stack[idx - 2] = x;
            stack[idx - 1] = y;
          }
        }
      }
    }
  
    return true;
  }

};
</script>

Test runner

Warning! For accurate results, please disable Firebug before running the tests. (Why?)

Java applet disabled.

Testing in CCBot 2.0.0 / Other 0.0.0
Test Ops/sec
Recursive
equals1(data1, data2);
pending…
Loop
equals2(data1, data2);
pending…
Test
equals3(data1, data2);
pending…

You can edit these tests or add even more tests to this page by appending /edit to the URL.

0 Comments