search
HomeDevelopment ToolsgitAre the implementation principles of git and svn the same?

The implementation principles of git and svn are different; git is a distributed version control system, svn is not. This is the core difference between git and svn non-distributed version control systems. It is stored in metadata mode, while svn is stored in file mode.

Are the implementation principles of git and svn the same?

The operating environment of this article: Windows 10 system, Git version 2.30.0, Dell G3 computer.

Are the implementation principles of git and svn the same?

Git is an open source distributed version control system used to handle any problem quickly and efficiently. Projects small or large.

Git is an open source version control software developed by Linus Torvalds to help manage Linux kernel development.

Git is different from commonly used version control tools such as CVS and Subversion. It uses a distributed version library and does not require server-side software support.

1. 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 a person with a background in using SVN, you need to make certain ideological changes to adapt to some concepts and features provided by GIT.

Differences between Git and SVN:

  • 1. GIT is distributed, SVN is not: this is GIT and other non-distributed version control systems, such as SVN , CVS, etc., the core difference.

  • 2. GIT stores content as metadata, while SVN stores content as files: all resource control systems hide the metainformation of files in a file similar to .svn, .cvs etc. folder.

  • 3. GIT branches are different from SVN branches: branches are not special at all in SVN, they are just another directory in the repository.

  • 4. GIT does not have a global version number, but SVN does: So far, this is the biggest feature that GIT lacks compared to SVN.

  • 5. The content integrity of GIT is better than that of 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.

2. Git principle: Git workspace, temporary storage area and version library

Basic concepts

Let’s start with Understand the concepts of Git workspace, staging area and repository

Workspace: It is the directory you can see on your computer.

Temporary storage area: called stage, or index in English. It is generally stored in the index file (.git/index) under the ".git directory", so we sometimes call the temporary storage area the index (index).

Repository: There is a hidden directory .git in the workspace. This is not the workspace, but the Git repository.

The following figure shows the relationship between the work area, the staging area in the repository and the repository:

Are the implementation principles of git and svn the same?

The left side of the figure is the work area, with the version library on the right. The area marked "index" in the repository is the staging area (stage, index), and the area marked "master" is the directory tree represented by the master branch.

From the picture we can see that "HEAD" is actually a "cursor" pointing to the master branch. Therefore, where HEAD appears in the command shown in the figure, it can be replaced with master.

The area identified by objects in the figure is the Git object library, which is actually located in the ".git/objects" directory, which contains various created objects and content.

When the "git add" command is executed on a file modified (or added) in the workspace, the directory tree of the temporary storage area is updated, and the contents of the file modified (or added) in the workspace are written. to a new object in the object library, and the object's ID is recorded in the file index of the temporary storage area.

When performing a commit operation (git commit), the directory tree in the temporary storage area is written to the version library (object library), and the master branch will be updated accordingly. That is, the directory tree pointed by master is the directory tree of the temporary storage area at the time of submission.

When the "git reset HEAD" command is executed, the directory tree in the staging area will be rewritten and replaced by the directory tree pointed to by the master branch, but the workspace will not be affected.

When the "git rm --cached " command is executed, the file will be deleted directly from the temporary storage area, and the workspace will not be changed.

When the "git checkout ." or "git checkout -- " command is executed, the files in the workspace will be replaced with all or specified files in the temporary storage area. This operation is dangerous and will clear changes in the workspace that have not been added to the staging area.

When the "git checkout HEAD ." or "git checkout HEAD " command is executed, all or part of the files in the master branch pointed to by HEAD will be used to replace the staging area and the workspace. document. This command is also extremely dangerous, because it will not only clear the uncommitted changes in the workspace, but also clear the uncommitted changes in the staging area.

Recommended learning: "Git Tutorial"

The above is the detailed content of Are the implementation principles of git and svn the same?. For more information, please follow other related articles on the PHP Chinese website!

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Git and GitHub: Exploring Their Roles and FunctionsGit and GitHub: Exploring Their Roles and FunctionsMay 09, 2025 am 12:25 AM

The role and function of Git and GitHub in software development is to manage code and collaborative development. Git efficiently manages code versions through commit, branch and merge functions, while GitHub provides code hosting and collaboration tools such as PullRequest and Issues to improve team collaboration efficiency.

GitHub: Discovering, Sharing, and Contributing to CodeGitHub: Discovering, Sharing, and Contributing to CodeMay 08, 2025 am 12:26 AM

GitHub is the preferred platform for developers to discover, share and contribute code. 1) Find specific code bases through search functions, such as Python projects. 2) Create a repository and push code to share with developers around the world. 3) Participate in open source projects and contribute code through Fork and PullRequest.

Using Git with GitHub: A Practical GuideUsing Git with GitHub: A Practical GuideMay 07, 2025 am 12:11 AM

Git is a version control system, and GitHub is an online platform based on Git. The steps to using Git and GitHub for code management and team collaboration include: 1. Initialize the Git repository: gitinit. 2. Add files to the temporary storage area: gitadd. 3. Submit changes: gitcommit-m"Initialcommit". 4. Related to the GitHub repository: gitremoteaddoriginhttps://github.com/username/repository.git. 5. Push code to GitHub: gitpush-uoriginmaste

GitHub's Impact: Software Development and CollaborationGitHub's Impact: Software Development and CollaborationMay 06, 2025 am 12:09 AM

GitHub has a far-reaching impact on software development and collaboration: 1. It is based on Git's distributed version control system, which improves code security and development flexibility; 2. Through functions such as PullRequest, it improves team collaboration efficiency and knowledge sharing; 3. Tools such as GitHubActions help optimize the development process and improve code quality.

Using GitHub: Sharing, Managing, and Contributing to CodeUsing GitHub: Sharing, Managing, and Contributing to CodeMay 05, 2025 am 12:12 AM

The methods of sharing, managing and contributing code on GitHub include: 1. Create a repository and push code, and write README and LICENSE files; 2. Use branches, tags and merge requests to manage code; 3. Fork the repository, modify and submit PullRequest contribution code. Through these steps, developers can effectively use GitHub to improve development efficiency and collaboration capabilities.

Git vs. GitHub: A Comparative AnalysisGit vs. GitHub: A Comparative AnalysisMay 04, 2025 am 12:07 AM

Git is a distributed version control system, and GitHub is a Git-based collaboration platform. Git is used for version control and code management, while GitHub provides additional collaboration features such as code review and project management.

Git vs. GitHub: Understanding the DifferenceGit vs. GitHub: Understanding the DifferenceMay 03, 2025 am 12:08 AM

Git is a distributed version control system, and GitHub is an online platform based on Git. Git is used for version control, branch management and merger, and GitHub provides code hosting, collaboration tools and social networking capabilities.

GitHub: The Frontend, Git: The BackendGitHub: The Frontend, Git: The BackendMay 02, 2025 am 12:16 AM

Git is a back-end version control system, and GitHub is a front-end collaboration platform based on Git. Git manages code version, GitHub provides user interface and collaboration tools, and the two work together to improve development efficiency.

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

SecLists

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.

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Powerful PHP integrated development environment

MantisBT

MantisBT

Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

SublimeText3 Linux new version

SublimeText3 Linux new version

SublimeText3 Linux latest version