多人開發Xcode工程衝突,打不開解決辦法

来源:http://www.cnblogs.com/jgCho/archive/2016/08/09/5754231.html
-Advertisement-
Play Games

在公司多人協作開發,相信好多程式員都遇到非常憂傷的問題,就是工程打不開,這樣就無從下手,好多程式怨只能再從代碼伺服器上下載一份新的代碼,今天軍哥教你幾個小技巧,讓你的bigger瞬間提升一個檔次 在公司經常遇到這種非常憂傷的問題 在公司經常遇到這種非常憂傷的問題 出現這種問題是因為多人開發中,同時修 ...


在公司多人協作開發,相信好多程式員都遇到非常憂傷的問題,
就是工程打不開,這樣就無從下手,好多程式怨只能再從代碼伺服器上下載一份新的代碼,今天軍哥教你幾個小技巧,讓你的bigger瞬間提升一個檔次


在公司經常遇到這種非常憂傷的問題

出現這種問題是因為多人開發中,同時修改了工程文件(小碼哥彩票.xcodeproj),或者storyboard,xib,Assets.xcassets,文件,就是系統工程配置文件,導致工程打不開

解決方案

第一種解決方案 - 圖形化界面

  • 1.選中工程文件->右鍵顯示包內容


    右鍵顯示包內容
  • 2.雙擊這個文件,用Xcode打開


    雙擊這個文件,用Xcode打開
  • 3.打開之後顯示這個樣紙

    打開之後顯示這個樣紙
  • 4.使用快捷鍵 cmd + F(搜索),在彈出的搜索框中輸<<< 或者 >>> 或者 ====,其中的任何一個都行,然後敲一下回車(enter鍵)

如圖,結果是這樣的
  • 4.說明
    <<<<<<< HEAD代表是工程文件衝突的開始
    =====分割線
    >>>>>>> d0d695000a8e250672dad0b7954d7d18a6cc17a0結束

如圖


-5.刪掉>>>HEAD===>>>>>>>d0d695000a8e250672dad0b7954d7d18a6cc17a0,E16D957A1CD616610095F921 /* Resource */E1F1D2271CD602F5002AC55F /* MainViewController.swift */保留一個

  • 6.刪除之後

刪除之後的樣子
  • 7.重覆查找,如果還有衝突的地方,同上
  • 8.保存 cmd + s

    一定要保存
  • 9, (OK)到這裡你的工程文件已經可以打開了
  • 10.打工告成

工程文件已經打開

第二種解決方案-終端(命令行)

  • 1.cd 進入Xcode工程文件夾

回車
  • 2.輸入 ls(查看這個路徑下的目錄)

    查看當前路徑下的文件
  • 3.輸入cd vim project.pbxproj用vim編輯器查看工程文件

    回車進入工程文件
  • 4.看到的效果就是這樣

    看到的效果就是這樣
  • 5.科普 vim 編輯器的命令

    i 編輯
    / 查找
    dd 刪除游標所在行
    shift + zz 保存並退出
    :w 將緩衝區寫入文件,即保存修改
    :wq 保存修改並退出
    :x 保存修改並退出
    :q 退出,如果對緩衝區進行過修改,則會提示
    :q! 強制退出,放棄修改

註意: 在Vim編輯器下輸入命令是英文狀態

  • 6.輸入 / << + 回車 定位衝突地方

    如圖
  • 7.輸入dd
    a.刪除 <<<HEAD b. 刪除 ==== c.刪除 >>>>>>>d0d695000a8e250672dad0b7954d7d18a6cc17a d. 刪除 E16D957A1CD616610095F921 /* Resource */, 或者 E1F1D2271CD602F5002AC55F /* MainViewController.swift */, 自己選擇
  • 8.按照再次查詢如果還有錯誤重覆第 6 和第7步
  • 9.直到出現E486: Pattern not found: <<

    沒有發現錯誤
  • 10.到這裡離成功僅差1步,保存 輸入 shfit + zz 或者:wq 保存並退出

     
  • 11 OK 大工告成,你可以再次直接打開工程了,這個時候你會發現工程已經可以打開了

    工程已經打開,是不是覺得so easy

    到這裡相信大家都會了,如果覺得命令行不太好用的話,可以先用圖形化界面,然後慢慢使用命令行,如果用命令行用的熟練的話,你會覺得非常好用



 
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、何謂版本控制 它是一種軟體工程籍以在開發的過程中,確保由不同人所編輯的同一檔案都得到更新,它透過文檔控制記錄程式各個模塊的改動,併為每次改動編上序號,並且編輯錯誤之後還可以回溯到以前的版本 二、可供我們選擇的版本控制系統 1、VCS (本地版本控制) 2、VSS、CVS(集中版本控制) 3、Cl ...
  • 之前發表過一篇關於視錯覺的文章:《視錯覺:從一個看似簡單的自定義控制項說起》,雖然不是用iOS開發中的Mask來實現的,但是原理和Mask原理是一樣的,相當於手動給上面一層加了個Mask。當然用mask完全可以實現上篇博客中的效果,無論是使用Mask還是不使用Mask,都是利用了視錯覺,都是兩層不一樣 ...
  • Swift - UITableView展開縮放動畫 效果 源碼 https://github.com/YouXianMing/Swift-Animations ...
  • AndroidStudio(以後都簡稱AS),作為google的親兒子,終於出了個像樣的android ide,再也不用在eclipse中又是Adt,又是這又是那的,一大堆的集成了。廢話不多說,這個系列打算用AS+WebApi寫一個自己的Oa App(AS編寫App代碼,WebApi編寫介面代碼)。 ...
  • 非對稱加密演算法 RSA 介紹 1977年,三位數學家Rivest、Shamir 和 Adleman 設計了一種演算法,可以實現非對稱加密。 演算法原理: https://zh.wikipedia.org/wiki/RSA%E5%8A%A0%E5%AF%86%E6%BC%94%E7%AE%97%E6%B3 ...
  • 前言 1、UITextField 的創建 Objective C Swift 2、UITextField 的設置 Objective C Swift 3、textField 的編輯 協議方法,需遵守協議 UITextFieldDelegate,並設置代理 Objective C Swift 4、te ...
  • 一、原因: forceclose,意為強行關閉,當前應用程式發生了衝突。 NullPointExection(空指針),IndexOutOfBoundsException(下標越界),就連Android API使用的順序錯誤也可能導致(比如setContentView()之前進行了findViewB ...
  • 屬性是封裝數據的方式(參見第6條)。 屬性只是定義實例變數及相關存取方法所用的“語法糖”,所以也應遵循同實例變數一樣的規則。 分類機制,應該將其理解為一種手段,目標在於擴展類的功能,而非封裝數據。 儘管從技術上說,分類里也可以聲明屬性,但這種做法應該儘量避免。 原因是:除了“class-contin ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...