برنامه نویسی جاوا | Java
5.7K subscribers
1.11K photos
158 videos
379 files
1.18K links
🎓آکـــــــــادمی جاواپـــــــــــــــرو
آموزش پیش نیازهای برنامه نویسی
آموزش مقدماتی تا پیشرفته جاوا
آموزش Spring Boot
سفارش پروژه ، دوره و تدریس خصوصی: @rzutab
مشاهده دوره ها و ثبت نام👇
wwww.academyjavapro.com
گروه جاوا : @group_javapro
Download Telegram
#️⃣ #آگهی_استخدام_جاوا

دعوت به همکاری در پروژه حوزه انرژی

ما در یک پروژه فعال در حوزه انرژی به دنبال جذب همکاران متخصص در موقعیت‌های زیر هستیم:

مهندس تست نرم‌افزار

مهندس نرم‌افزار (مسلط به Java و Spring Boot)

مهندس DevOps


در صورتی که تمایل به همکاری دارید، لطفاً رزومه خود را به آدرس زیر ارسال فرمایید:

📩 sara.poursanati@gmail.com


➡️اشتراک 👍لایک 💬کامنت

⚡️ @javapro_ir
✈️@group_javapro
Please open Telegram to view this post
VIEW IN TELEGRAM
🗿2
📣بروزرسانی دوره جامع نخبگان میکروسرویس‌ها با Java و SpringBoot

🎞فیلم‌های آموزشی فصل‌ ۱۲ هم
اکنون به دوره اضاف شد.

🆕 تاریخ آخرین بروزرسانی: ۲۶ تیر ۱۴٠۴

🖥 مشاهده دوره

#میکروسرویس #جاوا #java
Please open Telegram to view this post
VIEW IN TELEGRAM
🔷 معرفی EJB (Enterprise JavaBeans) در Java EE

در واقع EJB یک فناوری قدرتمند در Java EE برای ساختن کامپوننت‌های سمت سرور هست که مسئول پیاده‌سازی منطق تجاری، مدیریت تراکنش‌ها، امنیت، و کنترل هم‌زمانی هستند.

انواع EJB:

1. Session Beans
برای پیاده‌سازی منطق تجاری استفاده می‌شن. سه نوع دارن:

* Stateless: بدون وضعیت بین درخواست‌ها
* Stateful: با حفظ وضعیت در بین درخواست‌ها
* Singleton: یک نمونه برای کل اپلیکیشن

2. Message-Driven Beans (MDB)
برای دریافت پیام‌ها از صف‌های JMS استفاده می‌شن (Asynchronous communication).


یک مثال ساده از یک Stateless EJB:


import jakarta.ejb.Stateless;

@Stateless
public class CalculatorBean {

public int add(int a, int b) {
return a + b;
}
}


📌 در اینجا، @Stateless مشخص می‌کنه که این EJB هیچ اطلاعاتی از درخواست قبلی نگه نمی‌داره و مناسب برای درخواست‌های سریع و مستقل هست.


🔐 مزایای استفاده از EJB:

* مدیریت خودکار تراکنش‌ها (بدون نیاز به نوشتن کد اضافی)
* پشتیبانی از Injection برای استفاده از دیگر EJBها
* کنترل هم‌زمانی و Security داخلی
* اتصال راحت به دیتابیس، JMS و سرویس‌های دیگر


#کاربرـحرفهـای


🆔 @javapro_ir
🆔 @group_javapro
👍5
🔷 ترکیب EJB و JPA برای ساخت منطق تجاری متصل به پایگاه‌داده

در بسیاری از پروژه‌های Java EE، برای پیاده‌سازی منطق تجاری به کمک EJB و ارتباط با دیتابیس به کمک JPA، از ترکیب این دو تکنولوژی استفاده می‌شود.

سناریو: ثبت و مدیریت کاربران

فرض کنید می‌خواهیم اطلاعات کاربران را در پایگاه‌داده ذخیره و بازیابی کنیم.


📌 ابتدا موجودیت JPA را تعریف می‌کنیم:


import jakarta.persistence.*;

@Entity
public class User {

@Id
@GeneratedValue
private Long id;

private String name;

private String email;

// Getter و Setterها
}



📌 سپس یک EJB برای منطق تجاری مرتبط با این موجودیت می‌سازیم:


import jakarta.ejb.Stateless;
import jakarta.persistence.*;

@Stateless
public class UserService {

@PersistenceContext
private EntityManager em;

public void addUser(String name, String email) {
User user = new User();
user.setName(name);
user.setEmail(email);
em.persist(user); // ذخیره در پایگاه‌داده
}

public User findUser(Long id) {
return em.find(User.class, id); // بازیابی کاربر بر اساس ID
}
}



💡 در اینجا:

* از @PersistenceContext برای Inject کردن EntityManager استفاده شده است.
* متد addUser عملیات Persist را انجام می‌دهد.
* متد findUser برای بازیابی اطلاعات از دیتابیس کاربرد دارد.
* تمام مدیریت تراکنش‌ها به صورت خودکار توسط EJB انجام می‌شود.

#کاربرـحرفهـای


🆔 @javapro_ir
🆔 @group_javapro
👍42
💻به عنوان یک توسعه‌دهنده میکروسرویس، موارد زیر را بیاموزید:

1. مبانی معماری میکروسرویس‌ها: مقایسه معماری یکپارچه (Monolithic) با میکروسرویس، ویژگی‌ها (استقلال، مقیاس‌پذیری، تاب‌آوری) و طراحی مرزهای میکروسرویس‌ها با استفاده از طراحی مبتنی بر دامنه (DDD - Domain-Driven Design).


2. ارتباط بین سرویس‌ها: ارتباط همزمان (مانند REST و gRPC) در مقابل ارتباط غیرهمزمان (مانند صف پیام‌ها)، طراحی API و نسخه‌بندی، معماری مبتنی بر رویداد و منبع‌یابی رویداد (Event Sourcing).


3. مدیریت داده‌ها: پایگاه داده مجزا برای هر سرویس، مدیریت داده توزیع‌شده (الگوی ساگا، 2PC، CQRS) و حفظ سازگاری داده بین سرویس‌ها.


4. استراتژی‌های استقرار: استفاده از کانتینرها (Docker)، ارکستراسیون (Kubernetes) و کشف و ثبت سرویس‌ها (Eureka، Consul).


5. فریم‌ورک‌ها و ابزارها: Spring Boot به همراه Spring Cloud برای میکروسرویس‌ها، و همچنین گزینه‌های جایگزین مانند Micronaut، Quarkus یا Dropwizard.


6. پروتکل‌های ارتباطی: APIهای RESTful و gRPC، سیستم‌های پیام‌رسانی مانند Kafka و RabbitMQ.


7. پایگاه‌های داده: پایگاه‌های داده SQL (مثل PostgreSQL، MySQL)، NoSQL (مثل MongoDB، Cassandra) و کش‌های توزیع‌شده (مانند Redis، Memcached).


8. خطوط CI/CD: ابزارهایی مانند Jenkins، GitHub Actions، GitLab CI و استراتژی‌های استقرار مانند Blue-Green و Canary deployment.


9. زیرساخت به‌صورت کد (IaC): ابزارهایی مانند Terraform، Ansible یا AWS CloudFormation.


10. لاگ‌برداری و پایش: لاگ‌برداری متمرکز (مانند ELK Stack، Splunk) و ابزارهای مانیتورینگ (مانند Prometheus، Grafana).


11. تاب‌آوری و تحمل خطا: الگوی مدارشکن (Circuit Breaker) با ابزارهایی مانند Hystrix و Resilience4j، الگوی Bulkhead و پیاده‌سازی تلاش مجدد (Retry).


12. امنیت: پروتکل‌های OAuth2 و OpenID Connect، و دروازه‌های API مانند Zuul، Spring Cloud Gateway و Kong.


13. تست میکروسرویس‌ها: تست واحد و یکپارچه، تست قرارداد (Contract Testing با Pact) و تست سرتاسری (End-to-End Testing).


14. الگوهای مقیاس‌پذیری: مقیاس‌پذیری افقی و عمودی، و توازن بار (Load Balancing) با ابزارهایی مانند HAProxy و NGINX.


15. ردیابی توزیع‌شده: ابزارهایی مانند Jaeger و Zipkin.


16. ضدالگوها (Anti-Patterns): اجتناب از تبدیل معماری میکروسرویس به یک مونو‌لیث توزیع‌شده و پرهیز از پیچیدگی و طراحی بیش‌ازحد.


➡️اشتراک 👍لایک 💬کامنت

⚡️ @javapro_ir
✈️@group_javapro
Please open Telegram to view this post
VIEW IN TELEGRAM
4
🟢 اجرای دستورات شل در جاوا

در بسیاری از پروژه‌های نرم‌افزاری، نیاز به اجرای دستورات سیستم‌عامل مانند mkdir، ls، rm یا حتی اسکریپت‌های کامل شل وجود دارد. زبان جاوا به صورت پیش‌فرض ابزارهایی برای اجرای این دستورات فراهم کرده است، اما گاهی برای داشتن کنترل بیشتر و ساده‌سازی فرایند اجرا، بهتر است از کتابخانه‌های خارجی استفاده کنیم.

یکی از بهترین و پرکاربردترین کتابخانه‌ها برای اجرای دستورات شل در جاوا، کتابخانه Apache Commons Exec می‌باشد.


🔵 کتابخانه Apache Commons Exec چه مزایایی دارد؟

* امکان اجرای دستورات به‌صورت امن‌تر و کنترل‌شده‌تر
* پشتیبانی از زمان‌بندی و تایم‌اوت اجرای دستورات
* قابلیت دریافت کامل خروجی یا خطای اجرای دستور
* مناسب برای پروژه‌های سمت سرور و نرم‌افزارهایی که نیاز به تعامل با سیستم‌عامل دارند


🔷 نحوه استفاده از Apache Commons Exec در پروژه

برای استفاده از این کتابخانه، ابتدا باید آن را به پروژه‌ی خود اضافه کنید. در صورت استفاده از Maven، کد زیر را در فایل pom.xml قرار دهید:

<dependency>
    <groupId>org.apache.commons</groupId>
    <artifactId>commons-exec</artifactId>
    <version>1.3</version>
</dependency>



🔷 نمونه کد برای ایجاد پوشه با استفاده از دستور mkdir

import org.apache.commons.exec.*;

public class ShellCommandExample {
    public static void main(String[] args) {
        try {
            CommandLine cmd = new CommandLine("mkdir");
            cmd.addArgument("-p");
            cmd.addArgument("/tmp/myfolder");

            DefaultExecutor executor = new DefaultExecutor();
            int exitCode = executor.execute(cmd);

            System.out.println("کد خروج: " + exitCode);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}



🔷 نمونه کد برای اجرای دستور ls -la و گرفتن خروجی آن

import org.apache.commons.exec.*;

import java.io.ByteArrayOutputStream;

public class ShellListDirectory {
    public static void main(String[] args) {
        try {
            CommandLine cmd = CommandLine.parse("ls -la /tmp");

            ByteArrayOutputStream outputStream = new ByteArrayOutputStream();
            PumpStreamHandler streamHandler = new PumpStreamHandler(outputStream);

            DefaultExecutor executor = new DefaultExecutor();
            executor.setStreamHandler(streamHandler);

            executor.execute(cmd);

            String output = outputStream.toString("UTF-8");
            System.out.println("خروجی دستور:\n" + output);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}



🟡 نکته مهم امنیتی
در صورتی که پارامترهای دستور از ورودی کاربر دریافت می‌شود، حتماً آن‌ها را اعتبارسنجی و پاک‌سازی کنید تا از بروز حملات امنیتی مانند Command Injection جلوگیری شود.

#کاربرـپیشرفته


🆔 @javapro_ir
🆔 @group_javapro
👍5
💻می‌خواهی در مصاحبه بعدی برنامه‌نویس جاوا موفق باشی؟
برای درخشش در مصاحبه‌ی بعدی‌ات، این موضوعات را آماده کن:


موضوع ۱: جریان پروژه و معماری آن

در مورد پروژه‌ای که انجام داده‌اید و معماری آن توضیح دهید. چه چالش‌هایی داشتید؟

نقش شما در این پروژه چه بود؟ از چه تکنولوژی‌هایی استفاده کردید و چرا همین‌ها را انتخاب کردید؟

چه مشکلی را در طول پروژه حل کردید؟ همکاری تیمی چگونه بود؟

از این پروژه چه درس‌هایی گرفتید؟

اگر به گذشته برگردید، چه چیزی را در این پروژه متفاوت انجام می‌دادید؟

موضوع ۲: مفاهیم پایه‌ی جاوا (Core Java)

مفاهیم رشته‌ها (String)، متدهای hashcode و equals

غیرقابل تغییر بودن (Immutability)

مفاهیم شی‌گرایی (OOP)

سریال‌سازی (Serialization)

چارچوب مجموعه‌ها (Collection Framework)

مدیریت استثناها (Exception Handling)

چندریسمانی (Multithreading)

مدل حافظه جاوا (Java Memory Model)

جمع‌آوری زباله‌ها (Garbage Collection)

موضوع ۳: جاوا نسخه‌های ۸، ۱۱، و ۱۷

ویژگی‌های جاوا ۸

متدهای پیش‌فرض و استاتیک

عبارت‌های لامبدا

واسط‌های تابعی (Functional Interfaces)

ر API مربوط به Optional

ر API مربوط به Stream

الگوهای تطابق (Pattern Matching)

بلوک‌های متنی (Text Block)

ماژول‌ها (Modules)

موضوع ۴: فریم‌ورک Spring، Spring Boot، معماری میکروسرویس و REST API

تزریق وابستگی و وارونگی کنترل (Dependency Injection/IOC)، Spring MVC

پیکربندی، Annotationها، عملیات CRUD

ر Beanها، Scopeها، Profileها و چرخه‌ عمر Bean

ر ApplicationContext و BeanContext

ر AOP، مدیریت استثناها، کنترل Advice

امنیت (JWT، OAuth)

ر Actuatorها

ر WebFlux و چارچوب Mono

متدهای HTTP

ر JPA

مفاهیم میکروسرویس

ر Spring Cloud

موضوع ۵: Spring و Hibernate، JPA و پایگاه داده (SQL یا NoSQL)

ریپازیتوری‌های JPA

ارتباط بین Entityها

کوئری‌های SQL مربوط به کارکنان و دپارتمان‌ها

کوئری‌های مربوط به حقوق n‌ام بیشترین مقدار

مفاهیم پایگاه‌ داده رابطه‌ای و غیررابطه‌ای

عملیات CRUD در پایگاه داده

جوین‌ها، ایندکس‌ها، پروسیجرها و توابع

موضوع ۶: کدنویسی

سؤالات مرتبط با ساختمان داده و الگوریتم (DSA)

مرتب‌سازی و جستجو با استفاده از API جاوا

سؤالات کدنویسی با استفاده از Stream API

موضوع ۷: سوالات مرتبط با DevOps و ابزارهای استقرار

این نوع موضوعات اغلب توسط مدیران یا رهبران تیم مطرح می‌شود که روی آن‌ها کار می‌کنند،
بنابراین ممکن است به‌طور جدی از شما درباره ابزارهای مربوط به DevOps و استقرار سؤال کنند.
شما باید درک خوبی از ابزارهای رایج مانند Jenkins، Kubernetes، Kafka، Cloud و غیره داشته باشید.

موضوع ۸: بهترین شیوه‌ها (Best Practices)

مصاحبه‌کننده‌ها معمولاً علاقه‌مندند درباره الگوهای طراحی (Design Patterns) سؤال بپرسند.
ممکن است الگوهای رایجی مانند Singleton، Factory یا Observer را مطرح کنند تا ببینند شما می‌توانید از آن‌ها در کدنویسی استفاده کنید.

اگر نیاز داری این موضوعات را تبدیل به یک چک‌لیست آماده‌سازی یا فایل آموزشی کنم، خوشحال می‌شوم کمک کنم.

➡️اشتراک 👍لایک 💬کامنت

⚡️ @javapro_ir
✈️@group_javapro
Please open Telegram to view this post
VIEW IN TELEGRAM
👍83
🟢 پیام آموزشی جاوا – خواندن و نوشتن فایل‌های متنی با Java NIO

در نسخه‌های جدید جاوا، کلاس‌های مدرنی در بسته java.nio.file معرفی شده‌اند که کار با فایل‌ها را بسیار ساده‌تر، خواناتر و قدرتمندتر می‌کنند. این کلاس‌ها شامل Files و Paths هستند و جایگزین مناسبی برای کلاس‌های قدیمی‌تر مانند FileReader`، `BufferedReader و FileWriter محسوب می‌شوند.


🔵 برای خواندن فایل متنی به ساده‌ترین شکل ممکن

با استفاده از متد Files.readAllLines می‌توان کل محتوای یک فایل متنی را به صورت لیستی از رشته‌ها خواند:


import java.nio.file.*;
import java.io.IOException;
import java.util.List;

public class ReadFileExample {
public static void main(String[] args) {
try {
Path filePath = Paths.get("data.txt");
List<String> lines = Files.readAllLines(filePath);

for (String line : lines) {
System.out.println(line);
}
} catch (IOException e) {
e.printStackTrace();
}
}
}


در این مثال، تمام خطوط فایل data.txt خوانده شده و در خروجی چاپ می‌شود.


🔵 برای نوشتن متن در فایل

با استفاده از متد Files.write می‌توان متن یا لیستی از رشته‌ها را به راحتی در یک فایل نوشت:


import java.nio.file.*;
import java.io.IOException;
import java.util.Arrays;

public class WriteFileExample {
public static void main(String[] args) {
try {
Path filePath = Paths.get("output.txt");
Files.write(filePath, Arrays.asList("Hello World", "This is a text file"), StandardOpenOption.CREATE);
System.out.println("File written successfully.");
} catch (IOException e) {
e.printStackTrace();
}
}
}


در این مثال، اگر فایل output.txt وجود نداشته باشد، ایجاد شده و دو خط در آن نوشته می‌شود.


🔵 برای اضافه‌کردن محتوا به انتهای فایل (Append)

با اضافه‌کردن گزینه `StandardOpenOption.APPEND`، می‌توان متن جدید را به انتهای فایل اضافه کرد بدون آنکه محتوای قبلی پاک شود:


Files.write(filePath, Arrays.asList("New line added"), StandardOpenOption.CREATE, StandardOpenOption.APPEND);



🟡 نکات مهم هنگام استفاده از Java NIO

* مسیر فایل می‌تواند نسبی یا مطلق باشد؛ برای امنیت و پایداری بیشتر، از مسیرهای مطلق استفاده کنید.
* اگر فایل وجود نداشته باشد، بسته به گزینه‌های انتخابی، ممکن است ایجاد شود یا استثناء پرتاب شود.
* متدهای کلاس Files بسیار زیاد و قدرتمند هستند؛ مانند کپی، حذف، بررسی وجود فایل و...

#کاربرـپیشرفته


🆔 @javapro_ir
🆔 @group_javapro
👍5💯1👾1
🟢 تفاوت مفهومی بین `String` و `StringBuilder`

در زبان جاوا، کار با رشته‌ها یکی از رایج‌ترین عملیات برنامه‌نویسی است. اما درک تفاوت میان کلاس‌های String و StringBuilder تنها به میزان مصرف حافظه یا سرعت محدود نمی‌شود؛ بلکه به مفاهیم مهمی مانند ناپذیرفتاری (Immutability)، مدیریت حافظه (Heap & String Pool)، و نحوه پردازش در زمان اجرا (JVM optimizations) باز می‌گردد.


🔵 سوال:
چرا در حلقه‌های بزرگ یا عملیات‌های رشته‌ای پرتکرار، استفاده از String ممکن است باعث کندی عملکرد شود، در حالی که StringBuilder چنین مشکلی ایجاد نمی‌کند؟


🟡 پاسخ :

برای پاسخ به این سوال باید ابتدا یک مفهوم بنیادین را در جاوا بشناسیم:
کلاس String در جاوا immutable است، به این معنا که هیچ‌گاه مقدار داخلی آن پس از ایجاد تغییر نمی‌کند. زمانی که رشته‌ای جدید با String تعریف و مقداردهی می‌شود، در واقع یک شیء جدید در حافظه ساخته می‌شود و مقدار قبلی دست‌نخورده باقی می‌ماند.

مثال ساده:


String s = "hello";
s += " world";


در اینجا، مقدار "hello" در ابتدا در حافظه (معمولاً String Pool) ساخته می‌شود. سپس با انجام +=`، شیء جدیدی با مقدار `"hello world" ساخته می‌شود و s به آن اشاره می‌کند. شیء قبلی (`"hello"`) همچنان در حافظه باقی می‌ماند، حتی اگر قابل دسترسی نباشد.

اگر این عملیات در یک حلقه پرتکرار انجام شود:


String result = "";
for (int i = 0; i < 10000; i++) {
result += i;
}


در هر تکرار، یک شیء جدید ساخته می‌شود و رشته‌ها کپی می‌شوند. این کار همزمان باعث:

* مصرف زیاد حافظه
* افزایش بار روی Garbage Collector
* کاهش شدید عملکرد CPU


🟢 در مقابل، کلاس `StringBuilder` چگونه عمل می‌کند؟

کلاس StringBuilder mutable است، یعنی اجازه می‌دهد مقدار داخلی رشته تغییر یابد بدون اینکه شیء جدیدی ساخته شود.

همان مثال با StringBuilder:


StringBuilder result = new StringBuilder();
for (int i = 0; i < 10000; i++) {
result.append(i);
}


در اینجا، تنها یک شیء ساخته می‌شود و حافظه‌ی آن به‌صورت پویا رشد می‌کند. هیچ نیازی به ساخت ده‌هزار شیء جدید یا کپی رشته‌ها نیست. در نتیجه:

* مصرف حافظه بسیار پایین‌تر است
* سرعت اجرا بسیار بیشتر است
* همچنین GC فشار زیادی متحمل نمی‌شود


🔴 نتیجه‌گیری مفهومی

انتخاب بین String و StringBuilder فقط یک انتخاب نحوی یا تفاوت در API نیست. این انتخاب به درک عمیق از مدیریت حافظه و طراحی زبان جاوا برمی‌گردد. در واقع:

* از String زمانی استفاده کن که رشته‌ها قرار نیست تغییر کنند (مثلاً کلیدها، پیام‌های ثابت، مقایسه‌ها)
* از StringBuilder زمانی استفاده کن که قرار است عملیات‌های متوالی و زیاد روی رشته‌ها انجام شود

اگر این تفاوت را درست متوجه شوید، نه‌تنها کد بهینه‌تری می‌نویسید، بلکه بهتر با درونیات JVM و رفتار آن در مواجهه با رشته‌ها آشنا خواهید شد.

#کاربر_مبتدی


🆔 @javapro_ir
🆔 @group_javapro
👍131🙏1
👩‍💻 ما در رایان همافزا برای سبزتر شدن تابلوی موفقیتمون به رنگی تازه نیاز داریم...

🎨 نوبت توئه که رنگ تازه این تحول باشی!

👨‍💻 جذب برنامه‌نویس Java

🎯 تخصص و مهارت‌های مورد نیاز:
درک عمیق از زبان #برنامه‌نویسی #جاوا (Core Java)
تسلط بر مفاهیم #شی‌گرایی، الگوهای طراحی و #concurrency
تسلط بر RESTful #API
مسلط به Spring Framework 🌿
مسلط به Hibernate و #JPA
تسلط بر مفاهیم پایگاه داده‌: SQL و PL/SQL
آشنایی با ابزارهای توسعه مانند Unit Test و #Git
آشنایی با اصول Clean Code

🎁 مزایا و تسهیلات:
💳 وام
💼 پاداش ارزیابی عملکرد
🛡 بیمه تکمیلی
✈️ کمک هزینه سفر
🍱 کمک هزینه ناهار + صبحانه
🎁 هدایای مناسبتی
🕓 ساعت کاری شناور

📧 در صورت تمایل، رزومه خود را ارسال کنید:
hrmjobs@rayanhamafza.com


➡️اشتراک 👍لایک 💬کامنت

⚡️ @javapro_ir
✈️@group_javapro
Please open Telegram to view this post
VIEW IN TELEGRAM
2
🟢 تفاوت عمیق بین `==` و `.equals()` در مقایسه اشیاء

در زبان جاوا، مقایسه‌ی دو متغیر به ظاهر مشابه، گاهی نتایج متفاوتی تولید می‌کند. درک دقیق تفاوت بین عملگر == و متد .equals() از مفاهیم کلیدی زبان جاوا است که تاثیر مستقیمی بر صحت و منطق برنامه خواهد داشت.


🔵 برای مقایسه اشیاء، عملگر `==` چه کاری انجام می‌دهد؟

با استفاده از `==`، جاوا بررسی می‌کند که دو متغیر دقیقاً به یک شیء یکسان در حافظه اشاره می‌کنند یا خیر. یعنی این عملگر، مقایسه‌ی هویت (Identity) را انجام می‌دهد، نه مقدار.


🔵 در مقابل، متد `.equals()` برای مقایسه‌ی چه چیزی به‌کار می‌رود؟

متد .equals() به‌صورت پیش‌فرض از کلاس Object به ارث رسیده و می‌تواند توسط کلاس‌ها بازنویسی (Override) شود تا مقدار داخلی شیء را بررسی کند. در نتیجه، مقایسه‌ی برابری منطقی (Value Equality) انجام می‌شود، نه فقط یکسان بودن آدرس در حافظه.


🔷 مثال مفهومی با `String`:


String a = "hello";
String b = "hello";
String c = new String("hello");

System.out.println(a == b); // true (به علت String Pool)
System.out.println(a == c); // false (شیء جدید در Heap)
System.out.println(a.equals(c)); // true (برابری محتوا)


در این مثال، رشته‌ی a و b به علت استفاده از String Pool به یک شیء اشاره دارند، پس == هم true می‌شود. اما c با استفاده از new ساخته شده و شیء جدیدی است، بنابراین a == c برابر با false خواهد بود، ولی a.equals(c) چون محتوا را بررسی می‌کند، برابر با true است.


🔷 مثال عمیق‌تر با کلاس سفارشی:


class User {
String name;
User(String name) {
this.name = name;
}
}

public class Test {
public static void main(String[] args) {
User u1 = new User("Ali");
User u2 = new User("Ali");

System.out.println(u1 == u2); // false
System.out.println(u1.equals(u2)); // false (تا زمانی که equals بازنویسی نشده باشد)
}
}


در اینجا حتی اگر name هر دو شیء برابر باشد، چون کلاس User متد .equals() را بازنویسی نکرده، مقایسه‌ی equals نیز مانند == فقط هویت را بررسی می‌کند و false باز می‌گرداند.


🔵 چگونه `.equals()` را بازنویسی کنیم؟

برای مقایسه‌ی منطقی محتوا، باید متد .equals() را در کلاس بازنویسی کنیم:


@Override
public boolean equals(Object obj) {
if (this == obj) return true;
if (obj == null || getClass() != obj.getClass()) return false;
User user = (User) obj;
return name.equals(user.name);
}


پس از این بازنویسی، u1.equals(u2) مقدار true خواهد داد چون مقدار name در هر دو برابر است.


🟡 نتیجه‌گیری

در جاوا، استفاده‌ی نادرست از == به‌جای .equals() یا بالعکس، می‌تواند منجر به بروز خطاهای منطقی شود که به‌راحتی قابل تشخیص نیستند. اگر می‌خواهید هویت (آیا این دو متغیر دقیقاً یک شیء هستند؟) را بررسی کنید، از == استفاده کنید. ولی اگر هدف شما مقایسه‌ی منطقی محتوا (آیا مقدارهای داخلی برابرند؟) است، باید از .equals() استفاده کرده و در صورت لزوم آن را بازنویسی نمایید.

درک این تفاوت یکی از پایه‌های مهم نوشتن کدی درست، قابل اعتماد و بدون خطا در زبان جاوا است.

#کاربر_مبتدی


🆔 @javapro_ir
🆔 @group_javapro
👍53
🚨 پایان دوران کران‌جاب‌ها نزدیک است! 💥 این‌طور توانستم اپلیکیشن Spring Boot خودم را با استفاده از Temporal برای آینده آماده کنم

در ابتدای کار، استفاده از وظایف زمان‌بندی‌شده (کران‌جاب) ساده به نظر می‌رسید؛ زمان‌بندی را تعیین می‌کردم، وظیفه اجرا می‌شد و تمام.
اما با رشد سیستم، مشکلاتی هم به‌مرور ظاهر شدند:

عدم تلاش مجدد هنگام بروز خطا
نبود امکان مشاهده اینکه چه چیزی اجرا شده یا شکست خورده
از دست رفتن وضعیت برنامه در صورت ری‌استارت شدن
پیچیدگی زیاد در هماهنگ‌سازی بین چندین وظیفه
ناسازگاری با معماری میکروسرویس‌های توزیع‌شده

در همین مرحله بود که با ابزار Temporal آشنا شدم؛ تغییردهنده‌ واقعی بازی.
Temporal باعث شد شیوه‌ نگاه من به وظایف زمان‌بندی‌شده عوض شود؛ حالا آن‌ها را به‌عنوان workflowهایی با دوام و مقاوم در برابر خطا پیاده‌سازی می‌کنم.

🔧 تغییراتی که در اپلیکیشن Spring Boot ایجاد کردم:

حذف منطق cron و جایگزینی با workflowهای Temporal
بهره‌مندی از تلاش مجدد، تایمر و پشتیبانی داخلی از وظایف طولانی‌مدت
ذخیره‌سازی وضعیت در خارج از سرویس، بدون نگرانی بابت ری‌استارت
امکان ردیابی، دیباگ و مانیتور کردن دقیق تمام وظایف
کدنویسی تمیز، تست‌پذیر و بدون ساختارهای آشفته و درهم

📌 فناوری‌هایی که استفاده کردم:

زبان جاوا به همراه فریم‌ورک Spring Boot

کیت توسعه Temporal

پایگاه داده PostgreSQL برای اطلاعات تجاری

داکر و کوبرنتیس برای استقرار و اجرای سیستم


امروز، وظایف پس‌زمینه‌ام قابل اعتماد، قابل پیگیری و به‌راحتی نگهداری‌پذیر شده‌اند — بدون اینکه نیمه‌شب مجبور شوم لاگ‌ها را بررسی کنم.

🚀 اگر شما هم در حال توسعه‌ میکروسرویس‌های مقیاس‌پذیر هستید، توصیه می‌کنم از مدل سنتی cron فاصله بگیرید.

بیایید از «محرک‌های زمان‌محور» به سمت «تفکر مبتنی بر workflow» حرکت کنیم.


➡️اشتراک 👍لایک 💬کامنت

⚡️ @javapro_ir
✈️@group_javapro
Please open Telegram to view this post
VIEW IN TELEGRAM
👍61
پیاده‌سازی ارتباط Real-Time با WebSocket در Spring Boot
فعال‌سازی پیام‌رسانی دوطرفه و با تأخیر کم در سرویس‌های جاوای خود با این پنج گام:


۱. افزودن وابستگی‌های WebSocket و STOMP
برای فعال‌سازی پشتیبانی از WebSocket و مدیریت پروتکل STOMP، کتابخانه‌های spring-boot-starter-websocket و spring-messaging را به پروژه اضافه کنید.

۲. پیکربندی EndPoint های WebSocket
یک EndPoint برای STOMP تعریف کنید (برای مثال: /ws) و قابلیت fallback به SockJS را فعال کنید تا از سازگاری بیشتر با مرورگرهای مختلف اطمینان حاصل شود.

۳. راه‌اندازی Message Broker
برای کاربردهای سبک، از بروکر درون‌حافظه‌ای (enableSimpleBroker) استفاده کنید. برای مقیاس‌پذیری افقی، اتصال به یک بروکر خارجی مانند RabbitMQ یا ActiveMQ را در نظر بگیرید.

۴. استفاده از SimpMessagingTemplate
با تزریق SimpMessagingTemplate به سرویس‌ها یا کنترلرها، می‌توانید پیام‌ها را به کلاینت‌هایی که در مسیرهایی مانند /topic/updates اشتراک دارند ارسال کنید.

۵. ایمن‌سازی کانال‌های WebSocket
با استفاده از Spring Security، درخواست‌های handshake مربوط به WebSocket را احراز هویت کرده و مسیرهای ارسال پیام را مجاز کنید.


➡️اشتراک 👍لایک 💬کامنت

⚡️ @javapro_ir
✈️@group_javapro
Please open Telegram to view this post
VIEW IN TELEGRAM
👍2
🎓لیست دوره های آکادمی جاواپرو:

💎 دوره پرتاب | آموزش پیش نیازهای برنامه نویسی

💎دوره مقدماتی جاوا

💎 دوره شاهکار پیشرفته جاوا

💎دوره طلایی Spring Core

💎دوره فریمورک Spring Boot

💎دوره پروژه محور Spring Boot-سیستم دانشگاه

💎دوره دژبان Spring Security

⚡️دوره جامع نخبگان میکروسرویس با Java و Spring Boot


همگی دوره ها دارای ضمانت بازگشت وجه می باشند.

🚀جایگاه فردایت، نتیجه‌ی تصمیم امروزت است

☎️پشتیبانی و راهنمای ثبت نام دوره ها 👇

☎️ @rzutab


➡️اشتراک 👍لایک 💬کامنت


⚡️ @javapro_ir
✈️@group_javapro
Please open Telegram to view this post
VIEW IN TELEGRAM
🟢 تفاوت بین متغیرهای `static` و `instance`

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


🔵 متغیرهای `instance` چیستند؟

هر بار که از یک کلاس، شیئی جدید ساخته می‌شود، یک نسخه‌ی مستقل از متغیرهای نمونه‌ای (`instance variables`) نیز در حافظه برای آن شیء ایجاد می‌شود. این متغیرها به شیء خاص تعلق دارند و مقادیرشان از شیئی به شیء دیگر متفاوت است.

مثال:


public class Counter {
int count = 0;
}


در اینجا هر شیء از کلاس Counter یک مقدار جداگانه برای count خواهد داشت.


🔵 متغیرهای `static` چیستند؟

متغیرهای static به کلاس تعلق دارند، نه به شیء. این متغیرها فقط یک بار در حافظه بارگذاری می‌شوند (معمولاً در Method Area از JVM) و توسط تمام اشیاء ساخته‌شده از آن کلاس به اشتراک گذاشته می‌شوند.

مثال:


public class Counter {
static int count = 0;
}


در این حالت، همه‌ی اشیاء از کلاس Counter به یک متغیر count یکسان دسترسی دارند و تغییر آن در یک شیء، برای سایر اشیاء نیز قابل مشاهده است.


🔷 مثال عمیق برای درک تفاوت:


public class Example {
int instanceVar = 0;
static int staticVar = 0;

public void increment() {
instanceVar++;
staticVar++;
}
}


و در تابع اصلی:


public class Main {
public static void main(String[] args) {
Example a = new Example();
Example b = new Example();

a.increment();
b.increment();

System.out.println("a.instanceVar = " + a.instanceVar); // 1
System.out.println("b.instanceVar = " + b.instanceVar); // 1

System.out.println("a.staticVar = " + a.staticVar); // 2
System.out.println("b.staticVar = " + b.staticVar); // 2
}
}


در اینجا:

* متغیر instanceVar به‌صورت مستقل در هر شیء ذخیره می‌شود.
* متغیر staticVar بین هر دو شیء مشترک است، پس در مجموع دو بار افزایش می‌یابد.


🟡 نکات مهم

* استفاده‌ی نادرست از متغیرهای static می‌تواند منجر به بروز باگ‌هایی شود که ردیابی آن‌ها دشوار است، به‌ویژه در برنامه‌های چندنخی.
* متغیرهای static پیش از ساخته‌شدن هر شیء و هنگام بارگذاری کلاس در JVM ایجاد می‌شوند.
* برای دسترسی به متغیرهای static نیازی به ساخت شیء نیست؛ می‌توان از طریق خود نام کلاس نیز به آن‌ها دسترسی داشت.

مثال:


Counter.count++;
System.out.println(Counter.count);



🟢 نتیجه‌گیری

درک تفاوت بین متغیرهای static و instance تنها به سطح سینتکس محدود نیست، بلکه در عمق طراحی شی‌گرا و درک نحوه‌ی مدیریت حافظه در جاوا قرار دارد. انتخاب صحیح میان این دو نوع متغیر، موجب پایداری، خوانایی و کارایی بهتر برنامه خواهد شد.

پیشنهاد می‌شود در زمان طراحی کلاس‌ها، ابتدا به این سوال پاسخ داده شود:
آیا این متغیر باید به هر شیء جداگانه تعلق داشته باشد یا فقط یک نسخه‌ی مشترک برای کل کلاس کافی است؟

پاسخ به این سوال، تعیین‌کننده‌ی انتخاب صحیح خواهد بود.

#کاربر_مبتدی


🆔 @javapro_ir
🆔 @group_javapro
👍7
👩‍💻شرح موقعیت شغلی جاوا

شرکت داده ورزی سداد با هدف ارائه خدمات به بانک ملی، محیطی پویا و به روز در حوزه خدمات فناوری اطلاعات ایجاد کرده است. فضایی که برای مواجه با چالش های جذاب، و رشد و توسعه فردی مناسب است.
اگر شما علاقمند به کار تیمی هستید و همکاری در چنین محیطی برای شما جذاب است، ما مشتاق آشنایی بیشتر هستیم.

مهارت های تخصصی شامل:

تسلط به زبان برنامه نویسی Java
تسلط به   Spring Boot 
تسلط به  JPA و Hibernate
تسلط به مفاهیم وب سرویس‌ها٬ REST API ٬ Soa و Micro service
تسلط به مفاهیم Design Patterns
تسلط به مفاهیم Object oriented
آشنایی با ابزارهای ساخت مانند Maven
آشنایی با مفاهیم پایگاه داده
آشنایی با ابزارها و رویه های توسعه نرم افزار مانند Unit Test ,CI/CD ,Git
آشنایی با ابزارها و راهکارها در زمینه کلان داده مثل Hadoop ,Redis ,Kafka ,Spark ٬ Graph database و سایر تکنولوژی ها و ابزارهای مرتبط
آشنایی با بسترهای راه اندازی Docker ,Kubernetes

شرح وظایف:

تحلیل و طراحی و پیاده سازی نرم افزار با زبان جاوا
پشتیبانی، رفع خطا و مشکلات و بروزرسانی سیستم های جاری
 
مهارت های دارای امتیاز:

علاقه­ مند به یادگیری تکنولوژی­ های جدید
حداقل 3 سال سابقه ایفای نقش بعنوان برنامه نویس Back-end (Java)
مهارت حل مسئله
روحیه ی اشتراک گذاری دانش و کار تیمی
پیروی از اصول Clean Code و تمایل به کد های کمتر و تمیزتر

📑ارسال رزومه


➡️اشتراک 👍لایک 💬کامنت


⚡️ @javapro_ir
✈️@group_javapro
Please open Telegram to view this post
VIEW IN TELEGRAM
👍2
نکته امشب جاوا: تفاوت بین JDK، JRE و JVM

🔹 ماشین مجازی جاوا (JVM): موتور اصلی اجرای بایت‌کد جاوا که باعث استقلال از پلتفرم می‌شود.

🔹 محیط اجرای جاوا (JRE): شامل ماشین مجازی جاوا به‌همراه کتابخانه‌های ضروری برای اجرای برنامه‌های جاوا است.

🔹 کیت توسعه جاوا (JDK): مجموعه‌ای کامل برای توسعه‌دهندگان که شامل محیط اجرای جاوا، کامپایلر و ابزارهایی برای نوشتن، کامپایل و اشکال‌زدایی کدهای جاوا می‌باشد.

👉 اگر فقط قصد اجرای برنامه‌های جاوا را دارید → به محیط اجرای جاوا (JRE) نیاز دارید
👉 اگر قصد توسعه برنامه‌های جاوا را دارید → به کیت توسعه جاوا (JDK) نیاز دارید
👉 و در هر حالت، ماشین مجازی جاوا (JVM) پشت صحنه کار اصلی را انجام می‌دهد.


➡️اشتراک 👍لایک 💬کامنت

⚡️ @javapro_ir
✈️@group_javapro
Please open Telegram to view this post
VIEW IN TELEGRAM
3
برنامه نویسی جاوا | Java
👩‍💻شرح موقعیت شغلی جاوا شرکت داده ورزی سداد با هدف ارائه خدمات به بانک ملی، محیطی پویا و به روز در حوزه خدمات فناوری اطلاعات ایجاد کرده است. فضایی که برای مواجه با چالش های جذاب، و رشد و توسعه فردی مناسب است. اگر شما علاقمند به کار تیمی هستید و همکاری در…
برخی افراد می‌پرسند برای استخدام شدن به عنوان برنامه‌نویس جاوا چه مهارت‌هایی نیاز است؟ پاسخ ساده است: کافی‌ست به سایت‌های کاریابی مانند جاب‌ویژن، جابینجا و سایر پلتفرم‌های مشابه مراجعه کنید. در بخش توضیحات آگهی‌های استخدام مرتبط با جاوا، فهرست دقیقی از مهارت‌ها و تخصص‌های مورد نیاز درج شده است برید همونا رو یاد بگیرید.


#️⃣در جاواپرو برخی از این تخصص ها رو آموزش دادیم

🌟 لیست دوره های آکادمی جاواپرو
Please open Telegram to view this post
VIEW IN TELEGRAM
👍4
الگوهای طراحی(Design Patterns)
مهم با مثال‌های واقعی از دنیای نرم‌افزار


۱. به‌روزرسانی خودکار فید در فیس‌بوک ← الگوی ناظر (Observer)
هر زمان پستی تغییر می‌کند، همه دنبال‌کنندگان به‌طور خودکار مطلع می‌شوند.

۲. فیلتر شدن پیام‌ها در اسلک ← الگوی زنجیره مسئولیت (Chain of Responsibility)
پیام‌ها به‌ترتیب از فیلتر اسپم، منشن‌ها و سپس اعلان‌ها عبور می‌کنند.

۳. ارتباط میان اپ‌های آیفون بدون آشنایی مستقیم ← الگوی میانجی (Mediator)
مرکز NSNotification پیام‌ها را بین اپلیکیشن‌ها هدایت می‌کند.

۴. عملکرد دقیق undo و redo در اپ Todoist ← الگوی فرمان (Command)
هر اقدام به صورت یک شیء قابل برگشت ذخیره می‌شود.

۵. کاهش نویز خودکار در تماس‌های زوم ← الگوی تزیین‌گر (Decorator)
پردازشگرهای صوتی به‌صورت لایه‌ای به جریان تماس افزوده می‌شوند.

۶. اتصال بدون مشکل سرویس‌های AWS به یکدیگر ← الگوی افزونه (Plugin)
مرزهای مشخصی بین ماژول اصلی و سرویس‌های جانبی وجود دارد.

۷. پردازش هزاران تراکنش در اپ‌های بانکی ← الگوی استخر اشیاء (Object Pool)
اتصالات پرهزینه به پایگاه داده، مجدداً استفاده می‌شوند.

۸. بازیابی خودکار در صورت خرابی سرورهای نتفلیکس ← الگوی تلاش مجدد (Retry)
تا رسیدن به وضعیت مطلوب، عملیات بارها امتحان می‌شود.

۹. ایجاد پلی‌لیست‌های شخصی در اسپاتیفای ← الگوی استراتژی (Strategy)
الگوریتم‌های مختلف براساس سلیقه موسیقی کاربران اجرا می‌شوند.

۱۰. همگام‌سازی فایل‌ها در گوگل درایو ← الگوی وضعیت (State)
رفتار فایل‌ها هنگام آپلود با زمانی که همگام شده‌اند متفاوت است.

۱۱. بارگذاری روان استوری‌ها در اینستاگرام ← الگوی پروکسی (Proxy)
ابتدا تصاویر پیش‌فرض نمایش داده می‌شوند تا تصاویر اصلی بارگذاری شوند.

۱۲. مدیریت انواع پیام در واتساپ ← الگوی کارخانه‌ای (Factory)
برای پیام متنی، تصویری یا صوتی، شیء مرتبط ساخته می‌شود.

۱۳. پخش‌کننده ویدیوی یوتیوب روی هر وب‌سایتی کار می‌کند ← الگوی تطبیق‌دهنده (Adapter)
پخش‌کننده با انواع سیستم‌های جاسازی هماهنگ می‌شود.

۱۴. نمایش یکنواخت املاک در Airbnb ← الگوی روش قالبی (Template Method)
ساختار نمایش ثابت است ولی اطلاعات هر ملک متفاوت است.

۱۵. اجرای اپلیکیشن اوبر روی همه پلتفرم‌ها ← الگوی پل (Bridge)
رابط کاربری از بخش‌های وابسته به سیستم‌عامل جدا شده است.


➡️اشتراک 👍لایک 💬کامنت

⚡️ @javapro_ir
✈️@group_javapro
Please open Telegram to view this post
VIEW IN TELEGRAM
1👍1
🔵 تفاوت Overloading و Overriding در جاوا – درک عمیق از رفتار متدها در زمان اجرا و کامپایل


در زبان جاوا، دو مفهوم Overloading (بارگذاری مجدد متد) و Overriding (بازنویسی متد) ممکن است در ظاهر مشابه به‌نظر برسند، اما در واقع تفاوت‌های بنیادی در هدف، زمان تشخیص، وابستگی به وراثت و رفتار در زمان اجرا دارند.

🔹 Overloading
بارگذاری مجدد متد زمانی اتفاق می‌افتد که چند متد با نام یکسان اما با تعداد یا نوع پارامترهای متفاوت در یک کلاس تعریف شوند. در این حالت، متدهای مختلفی با امضاهای متفاوت ایجاد می‌شوند و انتخاب اینکه کدام یک فراخوانی شود، در زمان کامپایل (Compile-time) و بر اساس نوع آرگومان‌ها انجام می‌شود.


public class Calculator {
public int add(int a, int b) {
return a + b;
}

public double add(double a, double b) {
return a + b;
}
}


در مثال بالا، متد add دوبار با پارامترهای متفاوت تعریف شده است، اما هر دو در یک کلاس هستند و وراثتی در کار نیست. این یعنی Overloading.

🔹 Overriding
بازنویسی متد زمانی اتفاق می‌افتد که یک کلاس فرزند، متدی را که از کلاس والد به ارث برده است، با همان امضا (نام، تعداد و نوع پارامترها) دوباره تعریف کند. این کار باعث تغییر رفتار آن متد برای اشیاء نوع فرزند می‌شود. تشخیص اینکه کدام نسخه از متد اجرا شود، در زمان اجرا (Runtime) و بر اساس نوع واقعی شیء انجام می‌شود.


class Animal {
public void speak() {
System.out.println("Animal speaks");
}
}

class Dog extends Animal {
@Override
public void speak() {
System.out.println("Dog barks");
}
}

public class Test {
public static void main(String[] args) {
Animal animal = new Dog();
animal.speak(); // خروجی: Dog barks
}
}


در این مثال، متد speak در کلاس Dog بازنویسی شده است. با وجود اینکه متغیر animal از نوع Animal تعریف شده، خروجی متد speak در زمان اجرا، وابسته به نوع واقعی شیء (`Dog`) است.


نکته مفهومی مهم:
در Overloading، انتخاب متد در زمان کامپایل و بر اساس امضای متد و نوع آرگومان‌ها انجام می‌شود.
در Overriding، انتخاب متد در زمان اجرا و بر اساس نوع واقعی شیء انجام می‌شود؛ این یعنی پلی‌مورفیسم واقعی در جاوا فقط با Overriding اتفاق می‌افتد.


درک دقیق این تفاوت، در طراحی کلاس‌های قابل توسعه، رعایت اصل Liskov Substitution و نوشتن کدی قابل نگهداری بسیار حیاتی است.

#کاربرـپیشرفته


🆔 @javapro_ir
🆔 @group_javapro
👍82