Java 프로그래머의 개발 효율성을 두 배로 높일 수 있는 방법이 있습니다.
애플리케이션의 컴퓨팅 딜레마
개발과 프레임워크 중 어느 것이 더 우선시되어야 할까요?
Java는 애플리케이션 개발에서 가장 일반적으로 사용되는 프로그래밍 언어입니다. 하지만 Java에서 데이터를 처리하는 코드를 작성하는 것은 간단하지 않습니다. 예를 들어, 다음은 두 필드에 대해 그룹화 및 집계를 수행하는 Java 코드입니다.
Map<Integer, Map<String, Double>> summary = new HashMap<>(); for (Order order : orders) { int year = order.orderDate.getYear(); String sellerId = order.sellerId; double amount = order.amount; Map<String, Double> salesMap = summary.get(year); if (salesMap == null) { salesMap = new HashMap<>(); summary.put(year, salesMap); } Double totalAmount = salesMap.get(sellerId); if (totalAmount == null) { totalAmount = 0.0; } salesMap.put(sellerId, totalAmount + amount); } for (Map.Entry<Integer, Map<String, Double>> entry : summary.entrySet()) { int year = entry.getKey(); Map<String, Double> salesMap = entry.getValue(); System.out.println("Year: " + year); for (Map.Entry<String, Double> salesEntry : salesMap.entrySet()) { String sellerId = salesEntry.getKey(); double totalAmount = salesEntry.getValue(); System.out.println(" Seller ID: " + sellerId + ", Total Amount: " + totalAmount); } }
반대로 SQL은 훨씬 간단합니다. GROUP BY 절 하나로 계산을 종료할 수 있습니다.
SELECT 연도(주문 날짜),판매자 ID,합계(금액) FROM 주문 GROUP BY 연도(주문 날짜),판매자 ID
실제로 초기 애플리케이션은 Java와 SQL의 공동 작업으로 작동했습니다. 비즈니스 프로세스는 애플리케이션 측에서 Java로 구현되었으며, 데이터는 백엔드 데이터베이스에서 SQL로 처리되었습니다. 데이터베이스 제한으로 인해 프레임워크를 확장하고 마이그레이션하기가 어려웠습니다. 이는 현대 응용 프로그램에 매우 비우호적이었습니다. 더욱이, 데이터베이스가 없거나 데이터베이스 간 계산이 관련되어 있으면 SQL을 사용할 수 없는 경우가 많았습니다.
이를 고려하여 나중에 많은 애플리케이션이 완전한 Java 기반 프레임워크를 채택하기 시작했습니다. 여기서 데이터베이스는 간단한 읽기 및 쓰기 작업만 수행하고 비즈니스 프로세스와 데이터 처리는 특히 마이크로서비스가 등장할 때 애플리케이션 측에서 Java로 구현됩니다. 이렇게 하면 애플리케이션이 데이터베이스에서 분리되고 뛰어난 확장성과 마이그레이션성을 얻을 수 있으므로 앞서 언급한 Java 개발 복잡성에 직면하면서 프레임워크 이점을 얻는 데 도움이 됩니다.
우리는 개발이나 프레임워크라는 한 가지 측면에만 집중할 수 있는 것 같습니다. Java 프레임워크의 이점을 누리려면 개발의 어려움을 견뎌야 합니다. 그리고 SQL을 사용하려면 프레임워크의 단점을 허용해야 합니다. 딜레마가 생깁니다.
그럼 어떻게 하면 될까요?
Java의 데이터 처리 기능을 향상시키는 것은 어떻습니까? 이는 SQL 문제를 방지할 뿐만 아니라 Java 단점도 극복합니다.
실제로 Java Stream/Kotlin/Scala가 모두 그렇게 하려고 노력하고 있습니다.
스트림
Java 8에 도입된 Stream에는 다양한 데이터 처리 방법이 추가되었습니다. 위 계산을 구현하기 위한 스트림 코드는 다음과 같습니다.
Map<Integer, Map<String, Double>> summary = orders.stream() .collect(Collectors.groupingBy( order -> order.orderDate.getYear(), Collectors.groupingBy( order -> order.sellerId, Collectors.summingDouble(order -> order.amount) ) )); summary.forEach((year, salesMap) -> { System.out.println("Year: " + year); salesMap.forEach((sellerId, totalAmount) -> { System.out.println(" Seller ID: " + sellerId + ", Total Amount: " + totalAmount); }); });
Stream은 실제로 코드를 어느 정도 단순화합니다. 그러나 전반적으로 여전히 SQL에 비해 번거롭고 덜 간결합니다.
코틀린
더 강력하다고 주장했던 Kotlin이 더욱 발전했습니다.
val summary = orders .groupBy { it.orderDate.year } .mapValues { yearGroup -> yearGroup.value .groupBy { it.sellerId } .mapValues { sellerGroup -> sellerGroup.value.sumOf { it.amount } } } summary.forEach { (year, salesMap) -> println("Year: $year") salesMap.forEach { (sellerId, totalAmount) -> println(" Seller ID: $sellerId, Total Amount: $totalAmount") } }
Kotlin 코드는 더 간단하지만 개선이 제한적입니다. SQL과 비교하면 아직 격차가 큽니다.
스칼라
그리고 스칼라가 있었습니다:
val summary = orders .groupBy(order => order.orderDate.getYear) .mapValues(yearGroup => yearGroup .groupBy(_.sellerId) .mapValues(sellerGroup => sellerGroup.map(_.amount).sum) ) summary.foreach { case (year, salesMap) => println(s"Year: $year") salesMap.foreach { case (sellerId, totalAmount) => println(s" Seller ID: $sellerId, Total Amount: $totalAmount") } }
Scala는 Kotlin보다 조금 더 간단하지만 여전히 SQL과 비교할 수는 없습니다. 게다가 스칼라는 너무 무거워서 사용하기 불편해요.
사실 이러한 기술은 완벽하지는 않지만 올바른 방향으로 가고 있습니다.
컴파일된 언어는 핫스왑이 불가능합니다
또한 컴파일된 언어인 Java에는 핫 스와핑에 대한 지원이 부족합니다. 코드를 수정하려면 재컴파일 및 재배포가 필요하며, 종종 서비스를 다시 시작해야 합니다. 이로 인해 요구 사항이 자주 변경될 때 최적이 아닌 경험이 발생합니다. 이에 비해 SQL은 이 점에 있어서 아무런 문제가 없습니다.
Java 개발은 복잡하고 프레임워크에도 단점이 있습니다. SQL은 프레임워크 요구 사항을 충족하는 데 어려움이 있습니다. 딜레마는 해결하기 어렵습니다. 다른 방법은 없나요?
궁극의 솔루션 – esProc SPL
esProc SPL은 순수하게 Java로 개발된 데이터 처리 언어입니다. 개발이 간단하고 프레임워크가 유연합니다.
간결한 구문
위의 그룹화 및 집계 작업에 대한 Java 구현을 검토해 보겠습니다.
Java 코드와 비교하면 SPL 코드가 훨씬 더 간결합니다.
Orders.groups(year(orderdate),sellerid;sum(amount))
SQL 구현만큼 간단합니다.
SELECT year(orderdate),sellerid,sum(amount) FROM orders GROUP BY year(orderDate),sellerid
사실 SPL 코드는 SQL 코드보다 단순한 경우가 많습니다. 순서 기반 및 절차적 계산을 지원하는 SPL은 복잡한 계산을 더 잘 수행합니다. 다음 예를 생각해 보세요. 주식의 연속 상승 일수의 최대 수를 계산합니다. SQL에는 쓰기는커녕 이해하기도 어려운 다음과 같은 3계층 중첩문이 필요합니다.
select max(continuousDays)-1 from (select count(*) continuousDays from (select sum(changeSign) over(order by tradeDate) unRiseDays from (select tradeDate, case when closePrice>lag(closePrice) over(order by tradeDate) then 0 else 1 end changeSign from stock) ) group by unRiseDays)
SPL은 단 한 줄의 코드로 계산을 구현합니다. 이는 Java 코드는 말할 것도 없고 SQL 코드보다 훨씬 간단합니다.
stock.sort(tradeDate).group@i(price<price[-1]).max(~.len())
Comprehensive, independent computing capability
SPL has table sequence – the specialized structured data object, and offers a rich computing class library based on table sequences to handle a variety of computations, including the commonly seen filtering, grouping, sorting, distinct and join, as shown below:
Orders.sort(Amount) // Sorting Orders.select(Amount*Quantity>3000 && like(Client,"*S*")) // Filtering Orders.groups(Client; sum(Amount)) // Grouping Orders.id(Client) // Distinct join(Orders:o,SellerId ; Employees:e,EId) // Join ……
More importantly, the SPL computing capability is independent of databases; it can function even without a database, which is unlike the ORM technology that requires translation into SQL for execution.
Efficient and easy to use IDE
Besides concise syntax, SPL also has a comprehensive development environment offering debugging functionalities, such as “Step over” and “Set breakpoint”, and very debugging-friendly WYSIWYG result viewing panel that lets users check result for each step in real time.
Support for large-scale data computing
SPL supports processing large-scale data that can or cannot fit into the memory.
In-memory computation:
External memory computation:
We can see that the SPL code of implementing an external memory computation and that of implementing an in-memory computation is basically the same, without extra computational load.
It is easy to implement parallelism in SPL. We just need to add @m option to the serial computing code. This is far simpler than the corresponding Java method.
Seamless integration into Java applications
SPL is developed in Java, so it can work by embedding its JARs in the Java application. And the application executes or invokes the SPL script via the standard JDBC. This makes SPL very lightweight, and it can even run on Android.
Call SPL code through JDBC:
Class.forName("com.esproc.jdbc.InternalDriver"); con= DriverManager.getConnection("jdbc:esproc:local://"); st =con.prepareCall("call SplScript(?)"); st.setObject(1, "A"); st.execute(); ResultSet rs = st.getResultSet(); ResultSetMetaData rsmd = rs.getMetaData();
As it is lightweight and integration-friendly, SPL can be seamlessly integrated into mainstream Java frameworks, especially suitable for serving as a computing engine within microservice architectures.
Highly open framework
SPL’s great openness enables it to directly connect to various types of data sources and perform real-time mixed computations, making it easy to handle computing scenarios where databases are unavailable or multiple/diverse databases are involved.
Regardless of the data source, SPL can read data from it and perform the mixed computation as long as it is accessible. Database and database, RESTful and file, JSON and database, anything is fine.
Databases:
RESTful and file:
JSON and database:
Interpreted execution and hot-swapping
SPL is an interpreted language that inherently supports hot swapping while power remains switched on. Modified code takes effect in real-time without requiring service restarts. This makes SPL well adapt to dynamic data processing requirements.
This hot—swapping capability enables independent computing modules with separate management, maintenance and operation, creating more flexible and convenient uses.
SPL can significantly increase Java programmers’ development efficiency while achieving framework advantages. It combines merits of both Java and SQL, and further simplifies code and elevates performance.
SPL open source address
위 내용은 Java 프로그래머의 개발 효율성을 두 배로 높일 수 있는 방법이 있습니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undress AI Tool
무료로 이미지를 벗다

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

해시 맵은 Java의 해시 테이블을 통해 키 값 쌍 스토리지를 구현하며, 그 핵심은 데이터 위치를 빠르게 배치하는 데 있습니다. 1. 먼저 키의 hashcode () 메소드를 사용하여 해시 값을 생성하고 비트 작업을 통해 배열 인덱스로 변환합니다. 2. 다른 객체가 동일한 해시 값을 생성하여 충돌을 일으킬 수 있습니다. 현재 노드는 링크 된 목록의 형태로 장착됩니다. JDK8 후 링크 된 목록이 너무 길고 (기본 길이 8) 효율을 향상시키기 위해 빨간색과 검은 색 트리로 변환됩니다. 3. 사용자 정의 클래스를 키로 사용하는 경우 equals () 및 hashcode () 메소드를 다시 작성해야합니다. 4. 해시 맵은 용량을 동적으로 확장합니다. 요소 수가 용량을 초과하고 하중 계수 (기본 0.75)를 곱하면 확장 및 재사용; 5. 해시 맵은 스레드 안전이 아니며 Multithreaded에서 Concu를 사용해야합니다.

TOSETJAVA_HOMEONWINDOWS, FIRSTLOCATETEJDKINSTALLATIONPATH (예 : C : \ ProgramFiles \ java \ jdk-17), thencreateasystemenvaria blenamedjava_homewiththatpath.next, updatePathVariableByadding%java \ _home%\ bin, andverifythesetupusingjava-versionandjavac-v

가상 스레드는 동시성과 IO 집약적 시나리오에서 상당한 성능 이점을 가지고 있지만 테스트 방법과 해당 시나리오에주의를 기울여야합니다. 1. 정확한 테스트는 실제 비즈니스, 특히 IO 차단 시나리오를 시뮬레이션하고 JMH 또는 Gatling과 같은 도구를 사용하여 플랫폼 스레드를 비교해야합니다. 2. 처리량 간격은 분명하며, 일정이 가볍고 효율적이기 때문에 10 만 동시 요청보다 여러 배에서 10 배나 높을 수 있습니다. 3. 테스트 중에, 높은 동시성 수치를 맹목적으로 추구하고, 비 차단 IO 모델에 적응하고, 대기 시간 및 GC와 같은 모니터링 지표에주의를 기울일 필요가있다. 4. 실제 애플리케이션에서는 웹 백엔드, 비동기 작업 처리 및 많은 동시 IO 시나리오에 적합하지만 CPU 집약적 작업은 플랫폼 스레드 또는 포크 플랫폼에 여전히 적합합니다.

JDBC 트랜잭션을 올바르게 처리하려면 먼저 자동 커밋 모드를 끄고 여러 작업을 수행 한 다음 결과에 따라 커밋 또는 롤백을 수행해야합니다. 1. 트랜잭션을 시작하려면 Conn.SetAutoCommit (False)에게 전화하십시오. 2. 인서트 및 업데이트와 같은 여러 SQL 작업을 실행합니다. 3. 모든 작업이 성공한 경우 Conn.commit ()에게 전화하여 데이터 일관성을 보장하기 위해 예외가 발생하면 Conn.Rollback ()에게 전화하십시오. 동시에, 재 시도는 리소스를 관리하고, 예외를 올바르게 처리하고, 연결 유출을 피하기 위해 긴밀한 연결을 사용하는 데 사용해야합니다. 또한 연결 풀을 사용하고 부분적으로 롤백을 달성하기 위해 저장 포인트를 설정하고 성능을 향상시키기 위해 거래를 가능한 한 짧게 유지하는 것이 좋습니다.

링크 된 목록을 구현하기위한 핵심은 노드 클래스를 정의하고 기본 작업을 구현하는 것입니다. first 데이터 및 다음 노드에 대한 참조를 포함하여 노드 클래스를 만듭니다. linkedlist 클래스를 생성하여 삽입, 삭제 및 인쇄 기능을 구현합니다. hepend 메소드는 꼬리에 노드를 추가하는 데 사용됩니다. printList 메소드는 링크 된 목록의 내용을 출력하는 데 사용됩니다. deletewithValue 메소드는 지정된 값으로 노드를 삭제하고 헤드 노드와 중간 노드의 다른 상황을 처리하는 데 사용됩니다.

Servicemesh는 Java Microservice Architecture의 진화를위한 불가피한 선택이며, 그 핵심은 네트워크 논리 및 비즈니스 코드를 분리하는 데 있습니다. 1. Servicemesh는 부하 밸런싱, 퓨즈, 모니터링 및 기타 기능을 부상 에이전트를 통해 처리하여 비즈니스에 중점을 둡니다. 2. Istio Envoy는 중간 및 대형 프로젝트에 적합하며 Linkerd는 가볍고 소규모 시험에 적합합니다. 3. Java 마이크로 서비스는 Feign, Ribbon 및 기타 구성 요소를 닫고 발견 및 의사 소통을 위해 Istiod로 넘겨야합니다. 4. 배치 중 사이드카의 자동 주입을 보장하고 트래픽 규칙 구성, 프로토콜 호환성 및 로그 추적 시스템 구성에주의를 기울이고 점진적인 마이그레이션 및 사전 제어 모니터링 계획을 채택하십시오.

SimpleDateFormat을 작성하고 사용하여 NewsImpleDateFormat ( "yyyy-mm-ddhh : mm : ss")와 같은 형식 문자열을 전달해야합니다. 2. 사례 민감도에주의를 기울이고 혼합 단일 레터 형식과 YYYY 및 DD의 오용을 피하십시오. 3. SimpledateFormat은 스레드 안전이 아닙니다. 멀티 스레드 환경에서는 새 인스턴스를 만들거나 매번 ThreadLocal을 사용해야합니다. 4. 구문 분석 방법을 사용하여 문자열을 구문 분석 할 때 ParseException을 잡아야하며 결과에는 시간대 정보가 포함되어 있지 않습니다. 5. DateTimeFormatter 및 Lo를 사용하는 것이 좋습니다

Java Collection Framework의 성능을 향상시키기 위해 다음 4 가지 점에서 최적화 할 수 있습니다. 1. Arraylist에 대한 자주 임의의 액세스, 해시 세트에 대한 빠른 검색 및 동의 환경에 대한 동의어 맵과 같은 시나리오에 따라 적절한 유형을 선택하십시오. 2. 용량 확장 오버 헤드를 줄이지 만 메모리 폐기물을 피하기 위해 초기화 중에 용량 및로드 계수를 합리적으로 설정하십시오. 3. 불변의 세트 (예 : List.of ())를 사용하여 보안 및 성능을 향상 시키며 일정한 또는 읽기 전용 데이터에 적합합니다. 4. 메모리 누출을 방지하고 약한 참조 또는 전문 캐시 라이브러리를 사용하여 장기 생존 세트를 관리합니다. 이러한 세부 사항은 프로그램 안정성과 효율성에 큰 영향을 미칩니다.
