تیکه پاره های جاوا
526 subscribers
93 photos
24 videos
7 files
58 links
سلام خوش اومدید. اینجا یادداشت ها و تکه های جاوا رو کنار هم قرار میدیم :) مطالب کاملا اختصاصی و دستنویس هستند. کپی فقط با ذکر منبع و آیدی کانال❤️

📝برای تدریس پیام دهید
محمدرضا عظیمی‌فرد
🆔 @mrvj475
Download Telegram
This media is not supported in your browser
VIEW IN TELEGRAM
#مثبت_برنامه_نویس
مرتب سازی آرایه با روش Quick sort بصورت گرافیکی

💬 عالی بود :))
#dsa

🟡 @pieceJava
6👍2
🔆 معکوس کردن یک رشته


1️⃣
از طریق متد reverse از کلاس StringBuilder
String str = "PieceJava";
String reversed = new StringBuilder(str).reverse();


2️⃣ بکمک حلقه:
String input = "PieceJava";
String reversed="";
for (int i = input.length()-1; i>=0 ;i--) {
reversed+= input.charAt(i);
}
return reversed;


3️⃣ بصورت بازگشتی:
public String reverse(String input){
if(input.length()<=1) return input;
char firstChar = input.charAt(0);
String sub = input.substring(1);
return reverse(sub)+firstChar;
}


#exercise
========
☕️ @PieceJava
👍7😁1
#معرفی_سایت
#مثبت_برنامه_نویس
| MonkeyType |
همونطور که میدونید یکی از فاکتور های مهم در کدنویسی، سرعت تایپتونه :)

اگه دنبال یه سایت خوب برای افزایش و تست سرعت هستین، پیشنهادم سایت monkeyType هستش.
برای تست سرعت خیلی کامله (به انواع حالت ها میتونید تست بگیرید)

پ.ن: تقریبا همه ی زبان ها از جمله زبان فارسی رو هم ساپورت میکنه :)

@PieceJava
4👍1
تیکه پاره های جاوا
#کوییز
خروجی کد بالا کدوم میشه؟
Anonymous Quiz
43%
ece
14%
iece
35%
ecej
9%
iecej
👍9
🔆 تفاوت سرعت و کارایی میان الحاق کردن رشته با + و append از کلاس StringBuilder

↖️ همانطور که میدانید String یک نوع غیر قابل تغییر (Immutable) است اما از طریق StringBuilder میتوانید یک نوع تغییر پذیر از رشته ها ایجاد کنید.

این نکته را هم در ذهن داشته باشید که برای یک رشته فرضا به نام str مادامی که یک رشته را به آن الحاق میکنید، یک آبجکت جدید در String pool ایجاد شده و آدرس آن در str ذخیره میشود. مثلا برای کد زیر
String str = "Hello";
str +=" World";
در خط اول یک رشته "Hello" در String pool ایجاد میشود و در خط بعدی نیز رشته ی جدید "Hello World" در String pool مجددا ایجاد میشود. در نتیجه هر الحاق یک رشته ی جدید را در String pool ایجاد میکند ( مگر اینکه رشته ی الحاقی قبلا در String pool ایجاد شده باشد که در اینصورت jvm آدرس به آن رشته را باز میگرداند و دیگر رشته ی جدیدی ساخته نمیشود. البته این مورد رو بعدا در پست جداگانه و بطور تخصصی تر هم بررسی میکنیم).

اما در حقیقت، الحاق کردن رشته از طریق + یا StringBuilder.append() هر دو به یک صورت انجام میشود و هر دو هنگام کمپایل شدن یک نوع بایت کد را تولید میکنند. این یعنی اگر داشته باشیم:
str = str1 + str2 + str3
این قطعه کد دقیقا معادل تکه کد زیر خواهد بود:

str = new StringBuilder().sb.append(str1).append(str2).append(str3).toString();

به اینصورت که انگار با الحاق کردن چند رشته با +، به نحوی یک نمونه از StringBuilder ایجاد کرده ایم و همه ی رشته ها را با متد append به هم الحاق کرده ایم.

اما مسئله زمانی تفاوت پیدا میکند که بخواهیم در یک حلقه با تعداد تکرار بالا، الحاق را انجام دهیم. برای مثال تکه کد زیر را در نظر بگیرید:
long start = System.currentTimeMillis();
String str = "";
for(int i = 0;i<100000;i++){
str+="*";
}
long finish = System.currentTimeMillis();
System.out.println(finish-start+"ms");

اجرای این تکه کد برای الحاق 100000 کاراکتر شاید به اندازه ی 11000ms (یازده ثانیه) زمان ببرد تا بطور کامل اجرا شود (زمان اجرای این تکه کد روی هر ماشین متفاوت است و ممکن است برای شما کمتر یا بیشتر طول بکشد).

اما اگر از طریق StringBuilder این کار را انجام دهیم:

long start = System.currentTimeMillis();
StringBuilder str = new StringBuilder();
for(int i = 0;i<100000;i++){
str.append("*");
}
long finish = System.currentTimeMillis();
System.out.println(finish-start+"ms");
خواهید دید که زمان اجرا کاهش شدیدی پیدا میکند (مثلا 10 میلی ثانیه).
👈 در واقع در قطعه کد اول، بخاطر خاصیت Immutable بودن رشته ها، هر بار رشته ی جدیدی در String pool ایجاد میشود و آدرس آن به str داده میشود که این میتواند هزینه ی اضافی را تحمیل کند. اما در قطعه کد دوم، فقط یک آبجکت از StringBuilder ایجاد میشود و هر بار کاراکتری به دنباله کاراکتر های قبلی اضافه میشود(در واقع در این کلاس آرایه ای از جنس کاراکتر ها وجود دارد) و تا زمانی که toString را برای این کلاس صدا نزنید، کل کاراکتر ها در همین حالت و بصورت یک دنباله در این ارایه میمانند.

شاید بگویید پیشتر به این موضوع اشاره کردیم که + و append به یک صورت عمل میکنند اما به خاطر داشته باشید که با هر بار + یک نمونه از StringBuilder در heap ایجاد میشود. یعنی برای 100000 تکرار ما 100000 آبجکت ایجاد کرده ایم!

📌نتیجه گیری:
- اگر دستورات کوتاه برای الحاق چند رشته دارید، مستقیم از + استفاده کنید و حالشو ببرید😁
- اگر لازم است که الحاق در چندین مرحله صورت گیرد، پیشنهاد میشود که از StringBuilder استفاده کنید
#String #StringBuilder #concat
————
@PieceJava
👍74
رفقا فرض کنید یه آبجکت از StringBuilder داریم با یه دنباله کاراکتری خیلی بلند
StringBuilder sb = new StringBuilder("Very Long long long String.... );
حالا برای تبدیل رشته به آرایه ای از کاراکتر ها آیا بصورت زیر بنویسیم بهینه تره
char charArray = stringbuilder.toString().toCharArray()
یا بصورت زیر؟
char[] charArray = new char[stringbuilder.length()];
stringbuilder.getChars(0, stringbuilder.length(), charArray, 0);

👈دلیلتون رو هم توی کامنت ها بنویسید :)
8
تیکه پاره های جاوا
رفقا فرض کنید یه آبجکت از StringBuilder داریم با یه دنباله کاراکتری خیلی بلند StringBuilder sb = new StringBuilder("Very Long long long String.... ); حالا برای تبدیل رشته به آرایه ای از کاراکتر ها آیا بصورت زیر بنویسیم بهینه تره char charArray = stringbu…
خب احتمالا تا الان به نتیجه رسیده باشید (قطعا رسیدید، 1 ماه گذشته و قرار ندادن پاسخ از کم کاری بنده بوده🙈)

👈راه اول در اصل دوبار کاری هستش. یعنی ما دنباله ی کاراکتری را به رشته و سپس از طریق رشته به آرایه ای از کاراکتر ها تبدیل میکنیم و همین دوبار حافظه را اشغال میکند!
👈 اما راه دوم مستقیم از متد getChars کاراکتر ها را از stringBuilder دریافت و در ارایه charArray ذخیره میکند
7👍1
💠 تفاوت isEmpty و isBlank در رشته ها:

🔅 متد isEmpty زمانی خروجی ترو دارد که رشته ی شما خالی از هر گونه کاراکتر باشد.
🔅 متد isBlank زمانی خروجی ترو دارد که رشته ی شما خالی یا حتی شامل اسپیس باشد.

#string
@java
👍101
#معرفی_سایت
#پیشنهاد

یه ریپازیتوری خیلی باحال داخل گیتهاب وجود داره و بهتون نشون میده که چطوری تکنولوژی های معروفی که ازشون استفاده میکنید رو خودتون از صفر بنویسید :) مثلا گیت، داکر، دیتابیس و...
https://github.com/codecrafters-io/build-your-own-x
7👍2
💠 جاوابین (JavaBean)

در جاوا JavaBean در حقیقت قرار دادی است که مشخص میکند در هر کلاسی باید:
1. تمامی فیلد ها باید پرایوت باشد (دسترسی فقط از طریق setter/getter)
2. دارای یک کنستراکتور بدون آرگومان باشد (default constructor)
3. قابل سریال سازی باشد (Serializable). یعنی آبجکت های این کلاس میتوانند مستقیما در داخل استریم ها، فایل ها، دیتابیس و ... نوشته شوند.

🔆 یک نمونه از کلاسی که از چارچوب javaBean پیروی میکند:
public class User implements java.io.Serializable {

// Properties.
private Long id;
private String name;
private Date birthdate;

// Getters.
public Long getId() { return id; }
public String getName() { return name; }
public Date getBirthdate() { return birthdate; }

// Setters.
public void setId(Long id) { this.id = id; }
public void setName(String name) { this.name = name; }
public void setBirthdate(Date birthdate) { this.birthdate = birthdate; }

// Important java.lang.Object overrides.
public boolean equals(Object other) {
return (other instanceof User) && (id != null) ?
id.equals(((User) other).id) : (other == this);
}
public int hashCode() {
return (id != null) ? (getClass().hashCode() +
id.hashCode()) : super.hashCode();
}
public String toString() {
return String.format("User[id=%d,name=%s,birthdate=%d]"
, id, name, birthdate);
}
}

در واقع JavaBean قراردادیست که کتابخانه های زیادی بر پایه ی آن پیاده سازی شده اند.

@java
👍10🔥2
#معرفی_سایت
#پیشنهاد

بازم یه ریپازیتوری خیییلی کاربردی که اکثر الگوریتم های معروف رو به زبون های مختلف بازنویسی کردن( الی الخصوص جاوا / جاوا اسکریپت / سی و... ). پیشنهاد میکنم حتما بهش سر بزنین :) هر الگوریتمی بخواین اینجا هست

🔗 لینک

@Java
👍53🔥1
#معرفی_کتاب
#دیزاین_پترن
احتمالا تا الان چند باری اصطلاح دیزاین پترن به گوشتون خورده باشه. همونطور که میدونید دیزاین پترن ها مجموعه ای از الگو ها و تکنیک های توسعه ان که برای حل یکسری مسائل رایج در طراحی نرم افزار به کار گرفته میشن.
اما یکی از بهترین کتاب هایی که در یادگیری الگو های طراحی بشدت میتونه موثر باشه کتاب Dive Into DESIGN PATTERNS هستش.
توی کتاب 22 تا از معروف ترین الگو های طراحی بررسی شده + 8 اصل مهم که الگو ها بر پایه ی اونها نوشته شدن.
وجه تمایزش هم با مابقی کتاب ها، شیوه ی آموزشش هست. به اینصورت که برای هر الگوی طراحی چندین مورد بررسی شده:

کجا مشکل به وجود میاد؟
الگوی راه حل چیه؟
ساختار الگو به چه صورته؟
چه زمانی از الگو استفاد کنیم؟
توی دنیای حقیقی مشکل به چه صورت ظاهر میشه؟
مزایا و معایب استفاده از این الگو...

⭕️ قیمت توی مارکت ها مابین 250 تا 300
قیمت 215ت میتونین ازمون دریافت کنین😍
برای سفارش: @MRVJ475
👍21
#کوییز قبل خواب

@PieceJava
🔥4
تیکه پاره های جاوا
خروجی کد بالا چیست؟
💬 پاسخ کامل:

احتمالا شما هم انتظار خروجی دیگری رو داشتید اما نتیجه ی اجرای برنامه ی بالا، خطای کمپایل خواهد بود.😊
در واقع سینتکس جاوا به شما اجازه ی تعریف و مقدار دهی یک متغیر محلی در یک ایف / فور / وایل/ دو وایل تک استیتمنتی(تک دستوری) رو نمیده و یک متغیر محلی زمانی بعنوان استیتمنت ظاهر میشه که داخل بلاک کد { } قرار گرفته باشه. پس اگه فور بالا بصورت زیر نوشته بودیم، برنامه خروجی 100 رو داشت:
for(int i = 0;i<100;i++){
Creature creature = new Creature();
}
و یا ازونجا که برناممون قرار نیست از متغیر creature استفاده کنه، میتونستیم بصورت زیر هم بنویسیم:
for(int i = 0;i<100;i++)
new Creature();


@PieceJava
👍102
💠 استفاده از _ برای جداسازی ارقام در کد

از بعد جاوای 7، برای جداسازی و افزایش خوانایی ارقام بزرگ در جاوا، میتوانید از _ استفاده کنید. مثلا فرض کنید برای ذخیره شماره کارت که باید 4 رقم 4 رقم برای خوانایی بهتر جداسازی شود. برای مثال:
long x = 1_2_13_213_131L;
long population = 8_078_598_555L;
double db = 1_2_3.4_5_6;
int x4 = 5_______2;

در اصل وجود _ هیچ تاثیری در خروجی کد نخواهد داشت و فقط جنبه ی خوانایی دارد.
البته به یاد داشته باشید که در حالت های زیر، قرار دادن _ خطای کمپایل به همراه خواهد داشت:
1. قرار دادن _ در پایان یا شروع داده:
int x = _1;

2. قرار دادن _ در مجاورت نقطه ی اعشار:
```java
double d1 = 12_.2;
double d2 = 13._4;

3. قبل یا بعد از حروف پسوندی F یا L که بترتیب برای مشخص کردن داده های اعشاری و لانگ به کار گرفته میشوند:
long socialSecurityNumber1  = 999_99_9999_L; 

4. در جاهایی که از رشته ای از ارقام استفاده میکنید. برای مثال کد زیر خطای رانتایم دارد:
int x = Integer.parseInt("23_34");

————
〽️ @PieceJava
🔥93
💠 نمونه ای از کاربرد های اینترفیس
🕘 زمان مطالعه: 2:00

🔆 در این مثال میخواهیم به کمک اینترفیس به بخشی از داده های یک کلاس داخلی دسترسی پیدا کنیم.

🔅 فرض کنید کلاس داخلی به نام Node را تعریف کرده اید:
public class LinkedList<E>{
private class Node<E>{
...
}
...
}

💬لیست پیوندی (LinkedList) ساختمان داده ایست که در آن داده ها در قالب یک Node ذخیره و از طریق آدرس گره بعدی خود به همدیگر لینک میشوند. در واقع هر Node حامل داده و آدرس گره بعدی خودش است.

در مثال بالا هیچ لزومی ندارد که کاربر به محتویات کلاس Node دسترسی پیدا کند. برای همین کلاس Node را پرایوت میکنیم.
اما از طرفی فرض کنید که میخواهیم به کاربر اجازه ی دسترسی به خود داده ی ذخیره شده را صادر کنیم. (یعنی فقط به داده و نه چیز دیگری از این کلاس).
در این حالت از اینترفیس استفاده میکنیم. مثلا اینترفیس زیر را ایجاد میکنیم:
public interface Position<E>{
E getElement();
}

حالا برای کلاس داخلی Node اینترفیس Position را پیاده سازی میکنیم و از طریق متد getElement اجازه ی دسترسی به داده را صادر میکنیم:
public class LinkedList<E>{
private class Node<E> implements Position<E>{
E data;
Node next;
...
...
@Override
public E getElement(){
return data;
}
...
...
}
private Node<E> head;
private Node<E> tail;
...
...
public Position<E> getFirst(){
return head;
}
...
}

در متد getFirst خروجی متد را از جنس Position<E> قرار داده ایم. این در واقع باعث میشود که کاربر به Node در قالب یک Position<E> دسترسی داشته باشد و همین باعث محدود شدن دسترسی اش به متد های اینترفیس Position خواهد شد. بنابراین از آنجا که Position فقط یک متد getElement را دارد، کاربر بجز به متد getElement، به هیچ داده ی دیگری از کلاس Node دسترسی نخواهد داشت.

👈 نکته ی 1: البته فکر میکنم شما به این موضوع واقف باشید که چه لزومی به پیاده سازی Position<E> داریم وقتی که میتوانیم بگوییم:
public E getFirst(){
return head.data;
}

در حقیقت هدف محدود سازی دسترسی به کلاس داخلی بود و هر کجا که نیاز باشد به بخشی از کلاس داخلی اجازه ی دسترسی صادر کنید، میتوانید از اینترفیس استفاده کنید.
مثلا سناریویی را در نظر بگیرید که یک کلاس داخلی چندین نوع داده را نگهداری میکند. حالا میتوان با پیاده سازی اینترفیس ها در کلاس داخلی مشخص کرد که از طریق کلاس خارجی، به چه بخشی از داده های کلاس میتوان دسترسی پیدا کرد.

👈 نکته ی 2: مثال بالا از کتاب ساختمان داده ی Michael. T goodrich هستش. میتوانید از همین کتاب، صفحه ی 271، فصل 7، مبحث Positional Lists، این مثال رو بیشتر و دقیق تر بررسی کنید. در واقع از Position<E> برای پیاده سازی یک حالت خاص از پیمایش داده های لینکدلیست به کار گرفته میشود

#interface
———
@PieceJava
👍11
Media is too big
VIEW IN TELEGRAM
#مثبت_برنامه_نویس
یه مقایسه ی خیلی باحال از مسیریابی A* و الگوریتم Dijkstra

همونطور که میبینید تو این مقایسه:
- دایکسترا سرعت کمتر داره اما تضمین میکنه که سریعترین راه ممکن رو پیدا میکنه
- الگوریتم A* خیلی خیلی سریعتره اما تضمینی در پیدا کردن کوتاه ترین راه نیست
@PieceJava
👍52🔥1