文章目录
Git是一个分布式版本控制系统,我们所用的Gitee和Github就是Linux之父Linus Torvalds所写的版本控制器商业化以后的结果。
我们有时候会遇到这种情况:你的上司对你的第一版方案不满意于是让你回去修改,你几经修改总是不能让你的上司满意,最后你的上司要求你将你的第一版提供出来。
你可能是直接基于你的旧版本进行的修改,所以在你修改的同时你也丢失了你的旧版本。
基于这种情况,便有人开发了版本控制器,你可以将你的旧版本上传到版本控制器以后直接在旧版本上修改,如果需要旧版可以直接去版本控制器中查找。

.gitgnore是一个后缀的合集,在.gitgonre出现的后缀都不会被上传到Gitee。
在Linux下你可以使用vim对该文件进行修改

复制该仓库的链接,然后在服务器终端输入
git clone+链接强调一下这里要输入的用户名和密码都是你登陆Gitee时所用的账户名和密码
补充

在我的服务器下使用
ll无法看到.git,必须使用ls -al
进入到仓库以后发现有一个.git目录,这个目录其实就是本地仓库。所谓仓库其实就是一个目录,这个目录中存放着本地仓库的内容。而push也就是将.git中的文件同步到Gitee中。(Gitee中也有这个文件,不过隐藏了无法看到)
如果你没有的服务器还没有安装Git就使用sudo yum install -y git安装
git add .

要在你的仓库目录下才可以提交,并且只能提交你仓库目录下的文件。
使用添加命令以后并没有直接给你上传到Gitee中,只是将内容暂存到了一个临时区域。
git commit -m '测试提交'
在首次使用git commit时,会要求你输入你Gitee的的账户名和邮箱
-m选项后面跟的是提交日志,这个可不能乱写哦,否则和公开处刑没什么区别。
使用
git log命令就可以查看到你的提交日志,公司在开发项目时会公用仓库,也就是说所有人都可以看到你写的提交日志。
此时距离将代码文件只差最后一步了,我们只要再push一下,就可以将.git中的新增文件添加到Gitee中。
git push

然后你就可以看到你的本地文件已经提交到Gitee上了

要知道在Gitee上也是可以更改代码的,如果有人在Gitee上更改了代码,然后你又在服务器上新增了文件。这个时候就会造成冲突,因为本地文件不是最新的。此时就需要使用git pull拉取一下了。

用git pull将在Gitee更新的结果拉取到本地仓库以后再使用git push就可以继续上传文件了

如果遇到这种一堆看不懂的不知道啥情况的就按ctrl+c退出,然后就会弹出一个vim窗口,直接输入
:q!就可以了,退出后可以继续使用指令上传Gitee
这是一个用来查看暂存区和仓库文件变更状态的指令,当我没有新的更改时,使用git status就是如下结果:

如果有更改

在Gitee上不存在的文件,在第一次提交时必须走完三板斧。如果是对Gitee中已经存在的文件做更改则只需要使用三板斧的后两板斧即可。
在前面我们已经学过了vim编辑器,并且也在一直使用vim编写代码。对于有问题的代码,我们在Windows下使用的那些集成编译环境都是可以直接调试的。在Linux下则是通过gdb来达到调试代码的目的的。
如果你的服务器没有配置gdb则使用
sudo yum install -y gdb安装一下即可

在这里我创建一个mytest.cpp然后使用g++编译以后,想用gbd调试一下。但是服务器告诉我不能调试,然后反馈了一堆信息。前面刚说gdb是Linux下的调试器,为什么这里又不能调试?
这是因为程序有两个版本,分别是release和debug。
对于程序员来说,在编写代码的时候需要使用到调试这个功能,所以需要在程序中加入调试信息,这就是debug版。
但是对于用户来说,他们不会调试也不关心如何调试程序,他们只在乎程序好不好用。所以就不用在程序中加入调试信息(而且删掉调试信息会让程序更轻量化),所以发布版都是release版。
Linux中默认是release版本,所以这里说no debugging symbols。
说到默认,这里就来总结一下Linux中的默认行为吧:
gcc/g++默认行为
默认是动态链接(动态链接要加static)
默认是release
vim默认行为
默认打开就是命令模式
如果要使用gdb调试,那么在生成可执行文件的时候就要加上-g选项

前面提到,debug版本要加入调试信息而release就不用,这个最直观的表现就在于文件大小,加入了调试信息的debug肯定是要比没有调试信息的release版本要大

显示代码(l)
当我们使用gdb开始调试后,刚开始屏幕上并没有我的代码,当我输入l以后才会显示我的代码

默认是先显示十行,如果要继续往下显示就摁回车
也可以指定显示:
显示内部格式信息(readelf -s)

|是管道,同时使用多个指令的时候就需要使用管道
根据我们在Windows下使用编译器调试的经验来说,要调试一个程序打断点是必不可少的。
b(打断点)

info b(查看断点)

d+断点编号(删除对应编号的断点)

在Windows下调试分为逐过程和逐语句,gdb同样可以,此外gdb还支持单独调试某一个函数这样的功能。
r(运行调试,在断点处停下)

n(逐过程调试)

没有进入到函数内部,直接跳到了下一步
s(逐语句)

进入到函数内部调试
c(运行至下一个断点处)

bt(调用堆栈)

fin(运行完当前函数)

display/undisplay(相当于监视)

until(运行到指定行号)

set val(修改变量的值),p+变量(打印变量的值)

info locals(查看当前栈帧中的局部变量)

disable breakpoints(禁用断点)

对于Git和gdb的使用,掌握以上的指令就已经足够我们日常使用了。到此我们已经学过了软件安装包yum,地表最强编辑器vim,gcc/g++编译器,如何将代码上传到Git,掌握简单的gdb指令用于调试。已经有能力在Linux下编写代码了,所以开发工具的相关学习也就到此为止了。接下来我们将走向更底层,也就是系统编程。冥王说,一颗树越要向上,它的根就越要向下。要继续加油啊!
我正在学习如何使用Nokogiri,根据这段代码我遇到了一些问题:require'rubygems'require'mechanize'post_agent=WWW::Mechanize.newpost_page=post_agent.get('http://www.vbulletin.org/forum/showthread.php?t=230708')puts"\nabsolutepathwithtbodygivesnil"putspost_page.parser.xpath('/html/body/div/div/div/div/div/table/tbody/tr/td/div
我有一个Ruby程序,它使用rubyzip压缩XML文件的目录树。gem。我的问题是文件开始变得很重,我想提高压缩级别,因为压缩时间不是问题。我在rubyzipdocumentation中找不到一种为创建的ZIP文件指定压缩级别的方法。有人知道如何更改此设置吗?是否有另一个允许指定压缩级别的Ruby库? 最佳答案 这是我通过查看rubyzip内部创建的代码。level=Zlib::BEST_COMPRESSIONZip::ZipOutputStream.open(zip_file)do|zip|Dir.glob("**/*")d
类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc
很好奇,就使用rubyonrails自动化单元测试而言,你们正在做什么?您是否创建了一个脚本来在cron中运行rake作业并将结果邮寄给您?git中的预提交Hook?只是手动调用?我完全理解测试,但想知道在错误发生之前捕获错误的最佳实践是什么。让我们理所当然地认为测试本身是完美无缺的,并且可以正常工作。下一步是什么以确保他们在正确的时间将可能有害的结果传达给您? 最佳答案 不确定您到底想听什么,但是有几个级别的自动代码库控制:在处理某项功能时,您可以使用类似autotest的内容获得关于哪些有效,哪些无效的即时反馈。要确保您的提
假设我做了一个模块如下:m=Module.newdoclassCendend三个问题:除了对m的引用之外,还有什么方法可以访问C和m中的其他内容?我可以在创建匿名模块后为其命名吗(就像我输入“module...”一样)?如何在使用完匿名模块后将其删除,使其定义的常量不再存在? 最佳答案 三个答案:是的,使用ObjectSpace.此代码使c引用你的类(class)C不引用m:c=nilObjectSpace.each_object{|obj|c=objif(Class===objandobj.name=~/::C$/)}当然这取决于
我正在尝试使用ruby和Savon来使用网络服务。测试服务为http://www.webservicex.net/WS/WSDetails.aspx?WSID=9&CATID=2require'rubygems'require'savon'client=Savon::Client.new"http://www.webservicex.net/stockquote.asmx?WSDL"client.get_quotedo|soap|soap.body={:symbol=>"AAPL"}end返回SOAP异常。检查soap信封,在我看来soap请求没有正确的命名空间。任何人都可以建议我
关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。
我在我的项目目录中完成了compasscreate.和compassinitrails。几个问题:我已将我的.sass文件放在public/stylesheets中。这是放置它们的正确位置吗?当我运行compasswatch时,它不会自动编译这些.sass文件。我必须手动指定文件:compasswatchpublic/stylesheets/myfile.sass等。如何让它自动运行?文件ie.css、print.css和screen.css已放在stylesheets/compiled。如何在编译后不让它们重新出现的情况下删除它们?我自己编译的.sass文件编译成compiled/t
我想将html转换为纯文本。不过,我不想只删除标签,我想智能地保留尽可能多的格式。为插入换行符标签,检测段落并格式化它们等。输入非常简单,通常是格式良好的html(不是整个文档,只是一堆内容,通常没有anchor或图像)。我可以将几个正则表达式放在一起,让我达到80%,但我认为可能有一些现有的解决方案更智能。 最佳答案 首先,不要尝试为此使用正则表达式。很有可能你会想出一个脆弱/脆弱的解决方案,它会随着HTML的变化而崩溃,或者很难管理和维护。您可以使用Nokogiri快速解析HTML并提取文本:require'nokogiri'h
我想为Heroku构建一个Rails3应用程序。他们使用Postgres作为他们的数据库,所以我通过MacPorts安装了postgres9.0。现在我需要一个postgresgem并且共识是出于性能原因你想要pggem。但是我对我得到的错误感到非常困惑当我尝试在rvm下通过geminstall安装pg时。我已经非常明确地指定了所有postgres目录的位置可以找到但仍然无法完成安装:$envARCHFLAGS='-archx86_64'geminstallpg--\--with-pg-config=/opt/local/var/db/postgresql90/defaultdb/po