Job Recruitment Website - Job seeking and recruitment - How to teach yourself how to get started with Java?

How to teach yourself how to get started with Java?

The difficulty of self-study lies in not knowing where to start and how to learn, and there is no systematic learning path. Now dark horse programmers have recently launched a java learning roadmap, which has solved a very good problem. You can search and have a look.

First of all, the java Foundation

To learn any programming language, the first thing to learn is the basic grammar. The first step to start Java learning is, of course, to master computer basics, basic programming syntax, object-oriented, set, IO streams, threads, concurrency, exceptions and network programming, which we call JavaSE basics. When you master these contents, you can install desktop software such as Thunder download software, QQ chat client and attendance management system on your computer.

JavaSE foundation is the starting point of Java intermediate programmers, and it is the only way to help you from white to know how to program.

There are six sub-modules in the basic Java module to learn:

Technology tree

Second, the database

The most valuable thing about the Internet is data. Any programming language needs to solve the problem of data storage, and the key technology of data storage is database. Both MySQL and Oracle are database management systems that are widely welcomed by enterprises. The most common communication technologies between Java programs and databases are JDBC, Druid and C3P0. After learning these database technologies, you can master the database operation and maintenance technology, the design specification of complex business table structure, common SQL operations in work, software data storage and so on.

Database is not only a compulsory course for Java development engineers, but also a skill that other languages need to master. Used to store customer data during interaction.

This section includes relational databases and non-relational databases.

For example: MySQL, oracle, redis, MongoDB, etc. After learning the database, you can store the data in the database, or you can query the data from the database through SQL statements. Combined with Java projects, you can save the data of dynamic sites.

Technology tree

Third, front-end technology.

The web page that the browser presents to users is the front end, which has three basic technologies, namely Html, CSS and JavaScript. After learning this, in order to make a better and more dazzling interactive experience, we need to learn jQuery, ElementUI, Vue, Ajax and packaging tool webpack. After learning these technologies, we can develop WeChat applets, responsive websites, mobile websites, B2B2C shopping malls like JD.COM, and manage the backstage.

The Javaweb stage includes front end, database and dynamic web page. Javaweb is an introductory course for Internet projects and the basis for advanced courses.

First, let's look at the front panel. This plate mainly includes the following modules:

After learning the front-end technology, you can complete the preparatory work for front-end projects like JD.COM and Taobao.

Technology tree

Fourth, dynamic web pages.

Mastering the front-end technology can only make a static website, but its page data remains unchanged, while a dynamic website can display different contents according to the changed data in the database, which is more widely used, so programmers must learn to make a dynamic website. To use Java as a dynamic website, we need to learn a complete knowledge system such as Servlet, Filter, Session, Cookie, JSP, EL expression and JSTL. After learning, you can develop OA system, content website, BBS and so on.

Dynamic Web page is the basis of server-side programming for intermediate programmers and a necessary course for advanced framework learning. The framework and service bottom of post-learning are based on dynamic web technology.

This section includes the core technologies of Javaweb, including Servlet, requests, responses, Cookie and sessions. Through the study of these technologies, we can complete the dynamic site development, better complete the interaction between the server and the customer, and "move" the data on the page to make a small application system.

Technology tree

Verb (abbreviation of verb) programming enhancement

I have studied the basics of JavaSE before, but it is inefficient and has poor scalability in enterprise applications. Programming reinforcement is to strengthen the foundation of JavaSE, which will improve the execution efficiency of program processing business and enhance the scalability of the program. Programming reinforcement will strengthen multi-thread advanced learning, involving thread memory, thread communication and other technologies. After learning, you can increase the knowledge reserve of an intermediate programmer and lay a good foundation during or after the interview.

Programming hardening is an in-depth understanding and application of solving practical problems, which strengthens the foundation of JavaSE and supports the later automation framework and the underlying understanding of some service frameworks.

Programming enhancement module mainly includes the following modules: multithreading advanced, involving thread memory, thread communication and so on. JVM optimization, optimizing the bottom layer of JVM and improving the efficiency of project execution; NIO, synchronous non-blocking IO improves efficiency.

Learning this stage can optimize the original project and make the program faster and more stable.

Technology tree

Software project management of intransitive verbs

Company development is team collaborative development. In order to better grasp the actual development, we also need to learn the commonly used project management platform, version controller, project construction tools and automated deployment tools. There must be a version upgrade in project development. Managing project progress and version requires system platforms such as Git, Maven and Sonar. After learning software project management, you will master the actual development process of the whole project and the collaborative development tools used in the whole project development process.

JavaSE foundation is the starting point of Java intermediate programmers, and it is the only way to help you from white to know how to program.

Java basic module has six sub-modules: basic grammar, which can help you to establish basic programming logic thinking; Object-oriented, writing beautiful Java programs in an object-oriented way; Collection, the necessary technology to store data in later development; IO, the basic operation of reading and writing disk files; Multithreading and concurrency improve program efficiency; Exceptionally, the logic of writing code is more sound; Network programming, application server learning foundation, complete the remote transmission of data.

Learning this stage, you can complete some simple management systems, tank battle games, QQ communication and so on.

Technology tree

VII. Popular technical framework

After mastering Javaweb, I have the ability to develop enterprise practical projects, but the development efficiency is low, the code volume is large, the development cycle is long and the development cost is high. Some excellent framework technologies are widely used by enterprises to solve the above problems, so we still need to learn framework technologies. The mainstream SpringMVC technologies in project development include Spring MVC, Spring, MyBatis, MyBatis Plus and Spring Java. These framework technologies are all necessary skills for a good programmer.

It is completely possible to use Javaweb for enterprise-level development, but the development efficiency is relatively low, so the common logical operations are encapsulated to form a framework, so the framework is an introductory skill for enterprise development.

There are several mainstream frames in the popular frame board: spring frame, which occupies a dominant position, and its ecosystem involves many solutions; MyBatis framework, operating database with ORM idea.

After learning this section, you can develop real enterprise-level projects, and the projects you make will be more in line with the requirements of enterprises.

Technology tree

Eight, distributed architecture

Distributed microservice technology is needed. Through the study of this course, you can have the ability of large-scale SOA architecture and micro-service architecture, and master the necessary technology and practical experience of large-scale micro-service projects. In the process of enterprise development, the business volume and users are gradually increasing. In order to ensure the availability of the system, the system becomes more and more complex, and the number of R&D personnel is also increasing. It is difficult for everyone to maintain a complex system, and some contents are often modified, which leads to the whole body. Therefore, we need to upgrade the system architecture.

With the development of Internet, the complexity of business and the experience of users need to be improved, so the distributed architecture appears. This section mainly explains the related solutions of distributed architecture.

It mainly includes the following modules: DubboSpringBoot, a high-performance RPC service publishing and calling framework, which simplifies the initial construction and development process of Spring applications; Spring Cloud is an orderly collection of a series of frameworks such as service discovery registration, configuration center, load balancing, circuit breaker and data monitoring.

This part of the study can have the necessary technical and practical experience for the development of large-scale internet projects and lay the foundation for entering BATJ.

Technology tree

Nine, server middleware

In the distributed system architecture, asynchronous communication between services is one of the very common requirements, and the birth of message middleware is to solve this kind of problem. At present, the mainstream message middleware in the market includes RabbitMQ, RocketMQ and Kafka. We will learn from these three message middleware to realize asynchronous communication in distributed projects. After learning these, you can realize asynchronous communication of distributed projects, distributed application log collection, distributed transactions and so on.

Middleware is necessary in large-scale Internet projects. Service middleware can help each sub-module realize mutual access, message sharing or unified access. Including remote service framework middleware, such as Apache RPC framework Dubbo and so on. Message queuing middleware, such as: Alibaba open source distributed middleware RocketMQ, high throughput message publishing and streaming media service Kafka, etc.

Learning service middleware is a necessary technology for intermediate JavaEE engineers and JavaEE architects.

Technology tree

X. server technology

After the programs are developed, we package them and deploy them to the server to run, so we need to learn common server technologies. Common servers are Linux and Window server. Linux has high performance and is the mainstream at present. The project we write needs a software to run, and this software is called a web container. We need to install a web container on the server to publish the project. At present, the mainstream web containers are tomcat, jetty, nginx and undertow.

Whether using native Javaweb or using framework for development, the project needs to be released for people all over the world to access, and the server board can solve this problem, so the server is the necessary technology for project release. This section includes virtualization and web application server learning, mainly including the following modules: Vmware, virtual machine software; LinuxNginx, a server-specific system, is a reverse proxy server in cluster deployment; Tomcat, the main server used when the project is published.

After learning this section, we can publish the developed project to the server and let your friends access it remotely. Super cool!

Technology tree

XI。 Container technology

With the server operating system and web container, we can deploy an independent site. In the distributed system, if you use the single-machine deployment mode, you will invest a lot of manpower and have a great chance of making mistakes. Therefore, Docker, a server virtualization technology, is also called a necessary technology today. Docker can help operators achieve rapid deployment and batch maintenance. Using Kubernetes to realize automatic deployment, large-scale scalability and application container management.

Containerization technology is a hot topic in recent two years. The environment can be encapsulated by containerization technology, which is convenient for transplantation and greatly improves the development efficiency. This section includes container technology Docker and its platform management engine Kubernetes. Docker is an open source application container engine, which can package applications and dependency packages into a portable image, then publish it to any popular Linux or Windows machine, or be virtualized. Kubernetes is open source and used to manage containerized applications on multiple hosts in the cloud platform. The goal of Kubernetes is to make the deployment of containerized applications simple and efficient. Through the study in this section, you can quickly build an environment through the above technologies, save development time and improve development efficiency.

Technology tree

Twelve. Business solution

Enterprise development will encounter some common business scenarios, such as search engine, caching, task scheduling, workflow, report export, log management, system monitoring and so on. Then these common solutions also have excellent free open source middleware available. Such as ElasticSearch, Lucene, Solr, redis, MongoDB, slf4J, ECharts, Quartz, POI, etc. The business plan and technical difficulties of the business solutions course have solved more than 90% of the pain points and difficulties in the development of enterprises.

Although we already have the basic technology and advanced technology, if we want to combine it with enterprise development, we need to explore the business solutions of actual projects. This section collects real solutions in real business scenarios. Common business solutions include: search business scenario solution, log collection and analysis scenario solution, workflow engine scenario solution, task scheduling scenario solution, map development platform scenario solution, payment open platform scenario solution and chart visualization scenario solution. By analyzing the actual business to learn this set of solution technologies, you can reach the level of intermediate or even senior engineers.

Technology tree