我们已经学习了一段时间的
linux知识,我们也要学以致用一下,对于我们的知识更加的掌握,所以我们自己写一个小程序进度条。
但是再写进度条的时候,我们必须要掌握几个我们新接触的知识点
1.\r和\n的理解
2.缓冲区的理解
只有理解了这两个知识点,我们写起进度条才会变得十分简单。
\r和\n的理解我们再学C语言的时候,我们有很多字符,一种是可显字符,另一种是控制字符
我们在一行内容没有写完,然后要换到下一行的开始,我们要进行两个操作,第一个操作让光标从第一行跳到第二行,但是光标只是垂直向下跳,并没有在第二行的开始。这个操作就是换行。
所有第二个操作就是在第二行让光标跳到最开始的位置,这个操作就是回车。
所以现在我们的两个字符的意思就可以解释了
\r:回车。
\n换行
这时,有的同学就问,我们在C语言的时候,怎么用\n来换行加回车。这是我们在这个语言环境下我们将其简化,此时的\n就表示回车加换行。
我们一共测试三种情况,一种是两个都有
\r和\n,另一个是只有\n,最后一个是只有\r。
\r \n都存在我们看下图发现,我们在其中既有回车又有换行,所以其
linux的命令行在我们执行程序下面。
\n我们在上面说了,这是我们在这个语言环境下我们将其简化,此时的
\n就表示回车加换行。
所以结果和上面一样就参考上图就ok了。
\r \n我们可以猜想一下,我们的
\r \n都没有,我们的光标就在文本行的最后,所以我们的linux命令就直接跟在文本行后面,那么我们看结果是不是吧。
\r我们知道原理,我们可以自己猜一下实验结果,因为我们
\r,只有回车的效果,我们本来光标在文本行的最后一个字符旁边,但是我们识别到\r字符,所以,直接回车,光标来到了文本行的开始。这时linux的命令行就会从光标处开始,将我们的文本覆盖掉,我们就什们都看不到。
#include<stdio.h>
#include<unistd.h>
int main()
{
printf("hello world");
sleep(3);
}
我们发现,
hello world没有立刻刷新出来,数据一定在sleep期间被保存起来,但是我们加上\n,数据就会先显示出来。
就是因为缓冲区有自己的行缓冲刷新策略。
我们知道了上面两个知识点,
\r将光标回到最开始就可以将其覆盖掉,所以我们利用这个特点可以写一个倒计时小程序,我们先写一个10秒以内的倒计时小程序。
1 #include<stdio.h>
2 #include<unistd.h>
3
4 int main()
5 {
6 int i=0;
7 for(i=9;i>=0;i--)
8 {
9 printf("%d\r",i);
10
11 sleep(1);
12 }
13 return 0;
14 }
我们发现这样倒计时不显示,原因是数据存放在缓冲区里,我们没有刷新缓冲区,所以我们没有显示,所以我们修改一下就OK了
1 #include<stdio.h>
2 #include<unistd.h>
3
4 int main()
5 {
6 int i=0;
7 for(i=9;i>=0;i--)
8 {
9 printf("%d\r",i);
10 fflush(stdout);
11 sleep(1);
12 }
13 return 0;
15 }
这样我们的倒计时代码就改好了,但是如果我们突然变成10秒以后的,发现不能将两位数字都覆盖掉,因为最后由两位数变成了1位数,所以我们还要做一点修改。
1 #include<stdio.h>
2 #include<unistd.h>
3
4 int main()
5 {
6 int i=0;
7 for(i=9;i>=0;i--)
8 {
9 printf("%-2d\r",i);
10 fflush(stdout);
11 sleep(1);
12 }
13 return 0;
15 }
~
现在我们就可以开始我们的进度条了。
就是这样子的
[#########################################] [%100] [/]
其原理就是不断地覆盖,然后将其像早以前的动画片一样,变成一个动画。
第一个中括号就是表示进度条。第二个中括号表示进度。第三个表示旋转样式。
我们先创建三个文件,
proc.h,编写进度条的头文件
proc.c,编写进度条的函数
main.c,测试进度条
proc.h内容 1 #pragma once
2
3 #include <stdio.h>
4
5 void process(); ~
main.c内容 1 #include "proc.h"
2
3 int main()
4 {
5 process();
6 return 0;
7 }
proc.c内容其中这个是最重要的,他要包括我们当中的
process实现的函数.
代码中有解释,详细看代码
1 #include"proc.h"
2 #include<unistd.h>
3 #include<string.h>
4
5 // "|/-\"旋转标志
6 void process()
7 {
8 const char* lable ="|/-\\";
9
10 //为什们要定义101个字符?
11 //就是因为我们的进度条有100个
12 //但是字符的结尾要用\0表示所以我们要有101个字符
13 char bar[101];
14 //先将进度条设置为\0,然后在依次增加#。
15 memset(bar,'\0',sizeof(bar));
16 int i=0;
17 while(i<=100)
18 {
19 printf("[%-100s] [%d%%] [%c]\r",bar,i,lable[i%4]);
20 fflush(stdout);
21 bar[i++]='#';
22 usleep(100000);
23 }
24 printf("\n");
25
26 }
我们这个进度条就是将我们的知识融汇贯通,大家不是学习了新的东西,就是将知识学明白了,而是将我们的这些知识运用起来,才是学会了这些东西,所以我们大家一起加油!!!一起进步!!!
我需要在客户计算机上运行Ruby应用程序。通常需要几天才能完成(复制大备份文件)。问题是如果启用sleep,它会中断应用程序。否则,计算机将持续运行数周,直到我下次访问为止。有什么方法可以防止执行期间休眠并让Windows在执行后休眠吗?欢迎任何疯狂的想法;-) 最佳答案 Here建议使用SetThreadExecutionStateWinAPI函数,使应用程序能够通知系统它正在使用中,从而防止系统在应用程序运行时进入休眠状态或关闭显示。像这样的东西:require'Win32API'ES_AWAYMODE_REQUIRED=0x0
Rackup通过Rack的默认处理程序成功运行任何Rack应用程序。例如:classRackAppdefcall(environment)['200',{'Content-Type'=>'text/html'},["Helloworld"]]endendrunRackApp.new但是当最后一行更改为使用Rack的内置CGI处理程序时,rackup给出“NoMethodErrorat/undefinedmethod`call'fornil:NilClass”:Rack::Handler::CGI.runRackApp.newRack的其他内置处理程序也提出了同样的反对意见。例如Rack
使用带有Rails插件的vim,您可以创建一个迁移文件,然后一次性打开该文件吗?textmate也可以这样吗? 最佳答案 你可以使用rails.vim然后做类似的事情::Rgeneratemigratonadd_foo_to_bar插件将打开迁移生成的文件,这正是您想要的。我不能代表textmate。 关于ruby-使用VimRails,您可以创建一个新的迁移文件并一次性打开它吗?,我们在StackOverflow上找到一个类似的问题: https://sta
我需要从一个View访问多个模型。以前,我的links_controller仅用于提供以不同方式排序的链接资源。现在我想包括一个部分(我假设)显示按分数排序的顶级用户(@users=User.all.sort_by(&:score))我知道我可以将此代码插入每个链接操作并从View访问它,但这似乎不是“ruby方式”,我将需要在不久的将来访问更多模型。这可能会变得很脏,是否有针对这种情况的任何技术?注意事项:我认为我的应用程序正朝着单一格式和动态页面内容的方向发展,本质上是一个典型的网络应用程序。我知道before_filter但考虑到我希望应用程序进入的方向,这似乎很麻烦。最终从任何
我想要做的是有2个不同的Controller,client和test_client。客户端Controller已经构建,我想创建一个test_clientController,我可以使用它来玩弄客户端的UI并根据需要进行调整。我主要是想绕过我在客户端中内置的验证及其对加载数据的管理Controller的依赖。所以我希望test_clientController加载示例数据集,然后呈现客户端Controller的索引View,以便我可以调整客户端UI。就是这样。我在test_clients索引方法中试过这个:classTestClientdefindexrender:template=>
我想用ruby编写一个小的命令行实用程序并将其作为gem分发。我知道安装后,Guard、Sass和Thor等某些gem可以从命令行自行运行。为了让gem像二进制文件一样可用,我需要在我的gemspec中指定什么。 最佳答案 Gem::Specification.newdo|s|...s.executable='name_of_executable'...endhttp://docs.rubygems.org/read/chapter/20 关于ruby-在Ruby中编写命令行实用程序
我构建了两个需要相互通信和发送文件的Rails应用程序。例如,一个Rails应用程序会发送请求以查看其他应用程序数据库中的表。然后另一个应用程序将呈现该表的json并将其发回。我还希望一个应用程序将存储在其公共(public)目录中的文本文件发送到另一个应用程序的公共(public)目录。我从来没有做过这样的事情,所以我什至不知道从哪里开始。任何帮助,将不胜感激。谢谢! 最佳答案 无论Rails是什么,几乎所有Web应用程序都有您的要求,大多数现代Web应用程序都需要相互通信。但是有一个小小的理解需要你坚持下去,网站不应直接访问彼此
我尝试运行2.x应用程序。我使用rvm并为此应用程序设置其他版本的ruby:$rvmuseree-1.8.7-head我尝试运行服务器,然后出现很多错误:$script/serverNOTE:Gem.source_indexisdeprecated,useSpecification.Itwillberemovedonorafter2011-11-01.Gem.source_indexcalledfrom/Users/serg/rails_projects_terminal/work_proj/spohelp/config/../vendor/rails/railties/lib/r
刚入门rails,开始慢慢理解。有人可以解释或给我一些关于在application_controller中编码的好处或时间和原因的想法吗?有哪些用例。您如何为Rails应用程序使用应用程序Controller?我不想在那里放太多代码,因为据我了解,每个请求都会调用此Controller。这是真的? 最佳答案 ApplicationController实际上是您应用程序中的每个其他Controller都将从中继承的类(尽管这不是强制性的)。我同意不要用太多代码弄乱它并保持干净整洁的态度,尽管在某些情况下ApplicationContr
如果您尝试在Ruby中的nil对象上调用方法,则会出现NoMethodError异常并显示消息:"undefinedmethod‘...’fornil:NilClass"然而,有一个tryRails中的方法,如果它被发送到一个nil对象,它只返回nil:require'rubygems'require'active_support/all'nil.try(:nonexisting_method)#noNoMethodErrorexceptionanymore那么try如何在内部工作以防止该异常? 最佳答案 像Ruby中的所有其他对象