AroundAround
Sign in Sign up
Menu
  • Home
    • Home
  • Blog
    Technology
    All Technology Software Engineering Web Applications Java Spring Framework Spring Boot AWS
    All Posts
    Smash Posts Transportation Posts Driving Posts Multi Location Post
    Transport
    Driving Articles Driving License Resources Refresh Drive Success Stories Special Articles
    Research
    Popular lists Weblogs Tutorials
    News
    Education Health Sports
    Traffic Signs
    Dubai Traffic Signs Qatar Traffic Signs Abu Dhabi Traffic Signs Saudi Arabia Traffic Signs Kuwait Traffic Signs Kerala Traffic Signs
  • Insights
    Aptitude Test
    Software Engineering Apt Test
    Interview Series
    All Interview Series Java Questions Spring Questions Microservices Questions Database Questions
    Lifestyle
    Umrah Articles Dubai UAE visa 180 days calculator Qatar residence visa 180 days calculator Prayer Time Malappuram Sqm to Cent calculator Kerala
    City Explorer
    Sultan Bathery
    Career
    Career Selection New Gen Courses Colleges Salary Checker
  • Mock Tests
    Driving
    Test Home
    Dubai
    RTA Theory Test Parking Knowledge Test Deep-dive Assessment Test
    Abu Dhabi
    RTA Driving Theory Test Deep-dive Assessment Test Saudi Arabia Computer Test
    Other Regions
    Qatar Driving Theory Test Kuwait Driving Theory Test Ajman RTA Theory Test Sharjah RTA Theory Test Bahrain Driving Theory Test Learners License Test - Kerala
    Education
    Kindergarten School
  • Course & Videos
    • CoursesEnroll today
    • Videos20+Watch & Subscribe
  • Questions and Tags
    Topics
    Don't miss Million dollar questions Million Views Day to day life Interview Junky Trendy questions Theory wizard
    Technology
    Java Spring AWS
    Find the differences
    All Find the differences List
    Tags
    macOS AWS Spring
  • About Us
    • Privacy Policy
    • Contact
    • Terms & Conditions
    • Cancellation & Refund Policy
    • Shipping & Delivery Policy
  1. Home
  2. java
  3. Post

Why is "B" so much slower to print than "#"?

Emma Brown
admin
#java #programming
Share post:
Share

1000x1000 matrix. `#` prints fast, `B`...doesn't. Same code, wildly different execution times. Why? Console I/O mystery awaits!

Why is a 1000x1000 matrix of 'O' and '#' characters much faster to print than one of 'O' and 'B' characters in NetBeans 7.2's console? Ideone.com shows similar speeds, suggesting a local environment issue.

Solution in a Nutshell

Why is System.out.println("b") slower than other prints? (Java)

The perceived performance difference between System.out.println("b") and other print statements isn't inherent to the string itself. The bottleneck likely stems from JVM optimization and output buffering.

JVM Optimization: The JVM aggressively optimizes constant strings. "b" might be inlined, potentially leading to faster execution for some cases, especially within loops. However, this gain is minimal and usually masked by I/O overhead.

Output Buffering: System.out is buffered. Small outputs, like "b", might not immediately trigger a flush, while larger outputs might cause a flush, leading to perceived differences.

Reproducibility is Key: The Stack Overflow question lacks context. The slowdown might be due to other factors in the larger application, like network latency if the output is redirected.

Benchmarking: To accurately measure, use a proper benchmarking tool like JMH (Java Microbenchmark Harness). Raw System.currentTimeMillis() is unreliable.

//Illustrative (NOT a proper benchmark)
long start = System.nanoTime();
for (int i = 0; i < 1000000; i++) System.out.println("b");
long end = System.nanoTime();
System.out.println("Time: " + (end - start) / 1e9 + " seconds");

start = System.nanoTime();
for (int i = 0; i < 1000000; i++) System.out.println("longer string");
end = System.nanoTime();
System.out.println("Time: " + (end - start) / 1e9 + " seconds");

Conclusion: The performance discrepancy is unlikely due to "b" itself. Focus on accurate benchmarking and consider I/O buffering and other contextual factors before drawing conclusions. Use JMH for reliable measurements.

Sidebar

Search

Related

Post

`instanceof` null check needed?

Post

Isqrt Integer Check

Post

Java Array Concatenation

Post

File I/O: Create and Write

Tags

#java #programming

Trending posts

Post

Getters and Setters: Why Bother?

Post

Random String Outputting "Hello World"?

Post

Sorting a Map by Value

Post

Java: String to Enum

  • Contact Us
  • Privacy Policy

© Copyright - smashplus 2013-25.