What is the difference between svn and git?
The difference between git and svn
GIT is not only a version control system, it is also a content management system (CMS). Work management system etc. If you are someone with a background in using SVN, you need to make some mental changes to adapt to some of the concepts and features provided by GIT.
1. GIT is distributed, SVN is not:
This is the core difference between GIT and other non-distributed version control systems, such as SVN, CVS, etc. If you can understand this concept, you're halfway there. A little disclaimer needs to be made, GIT is not the first or only distributed version control system currently. There are also some systems, such as Bitkeeper, Mercurial, etc., that also run in distributed mode. But GIT does a better job in this regard and has more powerful features.
GIT, like SVN, has its own centralized repository or server. However, GIT prefers to be used in a distributed mode, that is, each developer will clone his or her own repository on his or her own machine after checking out the code from the central repository/server. It can be said that if you are trapped in a place without Internet access, such as on an airplane, in a basement, in an elevator, etc., you can still submit files, view historical version records, create project branches, etc. To some, this may not seem to be of much use, but when you suddenly encounter an environment without network, this will solve your big trouble.
Similarly, this distributed operating mode is also a huge gift to the development of the open source software community. You no longer have to make patch packages and send them out by email as before, you only need to create A branch that sends a push request to the project team. This keeps your code up to date and not lost in transit. GitHub.com is such an excellent case.
Some rumors have spread that future versions of subversion will also be based on distributed mode. But at least it's not visible yet.
2.GIT stores content by metadata, while SVN stores content by file:
All resource control systems hide the metainformation of files in a file similar to .svn, .cvs etc. folder. If you compare the size of the .git directory with that of .svn, you will find that they are very different. Because the .git directory is a cloned version of the repository on your machine, it has everything on the central repository, such as tags, branches, version records, etc.
3. GIT branches are different from SVN branches:
Branches are nothing special in SVN, they are just another directory in the repository. If you want to know whether a branch has been merged, you need to manually run a command like svn propget svn:mergeinfo to confirm whether the code has been merged. Thanks to classmate Ben for pointing out this feature. Therefore, it often happens that some branches are missed.
However, working with GIT branches is quite simple and fun. You can quickly switch between several branches from the same working directory. You can easily find unmerged branches, and you can merge these files quickly and easily.
4.GIT does not have a global version number, but SVN has:
So far, this is the biggest feature that GIT lacks compared to SVN. You also know that the SVN version number is actually a snapshot of the source code at any corresponding time. I think it is the biggest breakthrough in the evolution from CVS to SVN. Because GIT and SVN are conceptually different, I don't know what features in GIT correspond to them. If you have any clues, please share them in the comments.
Update: Some readers pointed out that we can use GIT's SHA-1 to uniquely identify a code snapshot. This does not completely replace the easy-to-read numerical version numbers in SVN. However, the purpose should be the same.
5. The content integrity of GIT is better than SVN:
GIT’s content storage uses the SHA-1 hash algorithm. This ensures the integrity of code content and reduces disruption to the repository in the event of disk failures and network problems.
Related recommendations: "Git Tutorial"
The above is the detailed content of What is the difference between svn and git. For more information, please follow other related articles on the PHP Chinese website!

GitHub is a Git-based version control system hosting platform that provides version control, collaborative development and community communication functions. Using GitHub can improve development efficiency and code quality.

Git and GitHub are different tools: Git is software for version control, and GitHub is an online platform based on Git. 1.Git allows you to track file changes and collaborative development. 2. GitHub provides code hosting and collaboration tools to enhance team development efficiency.

The core features of GitHub include version control, branch management, code review, issue tracking and project management. 1. Version control and branch management are based on Git, allowing tracking of code changes and experimental development. 2. Code review is implemented through PullRequest to improve code quality and team collaboration. 3. Issues tracking and project management are carried out through Issues and the project management board to improve project transparency and traceability.

GitHub is a powerful tool to improve the efficiency and quality of software development. 1) Version control: manage code changes through Git. 2) PullRequests: Conduct code review and improve code quality. 3) Issues: Track bugs and project progress. 4) GitHubActions: Automate the construction, testing and deployment process.

Git is a version control system, and GitHub is a Git-based code hosting platform. Git is used to manage code versions and supports local operations; GitHub provides online collaboration tools such as Issue tracking and PullRequest.

Git is an open source distributed version control system that helps developers track file changes, work together and manage code versions. Its core functions include: 1) record code modifications, 2) fallback to previous versions, 3) collaborative development, and 4) create and manage branches for parallel development.

Git and GitHub are not the same thing. Git is a version control system, and GitHub is a Git-based code hosting platform. Git is used to manage code versions, and GitHub provides an online collaboration environment.

The reason for using GitHub to manage HTML projects is that it provides a platform for version control, collaborative development and presentation of works. The specific steps include: 1. Create and initialize the Git repository, 2. Add and submit HTML files, 3. Push to GitHub, 4. Use GitHubPages to deploy web pages, 5. Use GitHubActions to automate building and deployment. In addition, GitHub also supports code review, Issue and PullRequest features to help optimize and collaborate on HTML projects.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

SublimeText3 Chinese version
Chinese version, very easy to use

SublimeText3 Mac version
God-level code editing software (SublimeText3)

SecLists
SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.

Dreamweaver Mac version
Visual web development tools

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool