在本章开始之前还是先给大家分享一张图片
这是C++的笔试题 感兴趣的同学可以去试一试 有难度的哟 也可以直接在牛服务器托管网客网直接搜索这几道题目哈
好了今天我们正式进入我们的正题部分
1.使用git命令行
安装git
yum install git
2.在github创建项目
使用 Github 创建项目
注册账号
创建项目
♨️1. 登陆成功后, 进入个人主页, 点击左下方的 New repository 按钮新建项目
2. 然后跳转到的新页面中输入项目名称(注意, 名称不能重复, 系统会自动校验. 校验过程可能会花费几秒钟). 校验
完毕后, 点击下方的 Create repository 按钮确认创建
3. 在创建好的项目页面中复制项目的链接, 以备接下来进行下载
下载项目到本地
创建好一个放置代码的目录
git clone [url]
这里的 url 就是刚刚建立好的 项目 的链接.
三板斧第一招: git add
将代码放到刚才下载好的目录中
git add [文件名]
将需要用 git 管理的文件告知 git
三板斧第二招: git commit
提交改动到本地
git commit .
最后的 “.” 表示当前目录
提交的时候应该注明提交日志, 描述改动的详细内容.
三板斧第三招: git push
同步到远端服务器上
git push
需要填入用户名密码. 同步成功后, 刷新 Github 页面就能看到代码改动了.
配置免密码提交
点击链接查看
3.Linux第一个小程序——进度条
#include
int main()
{
printf("hello Makefile!");
fflush(stdout);
sleep(3);
return 0;
}
进度条代码
#include
#include
int main()
{
int i = 0;
char bar[102];
memset(bar, 0 ,sizeof(bar));
const char *lable="|/-";
while(i 100 ){
printf("[%-100s][%d%%][%c]r", bar, i, lable[i%4]);
fflush(stdout);
bar[i++] = '#';
usleep(10000);
}
printf("n");
return 0;
}
当然这只是简单的版本 简单的版本我们昨天已经介绍过了 今天我们讲一下进阶版本的代码 大家仔细看 有一点复杂
下面是模拟下载进度的代码 这里需要注意几个细节 srand函数大家可以去Cplusplus官网去找一下 这是个时间戳的意思 只能生成依次 我在这里^1023的意思就只是为了让随机数更加随机一些 然后我们才能正常地使用我们的rand函数 后面的rate是浮点需要*100.0与之匹配
#include "processbar.h"
#include
#include
#include
#define FILESIZE 1024*1024*1024
//模拟一种场景,表示一种下载的任务
void download(callback_t cb) // 回调函数的形式
{
srand(time(NULL)^1023);
int total = FILESIZE;
while(total){
usleep(10000); //下载动作
int one = rand()%(1024*1024*10);
total -= one;
if(total 0) total = 0;
// 当前的进度是多少?
int download = FILESIZE - total;
double rate = (download*1.0/(FILESIZE))*100.0; // 0 23.4 35.6, 56.6
cb(rate);
//process_flush(rate);
//printf("download: %fn", rate); // rate出来了,应该让进度条刷新
}
}
int main()
{
//process();
download(process_flush);
return 0;
}
这个时候我们的进度条有了之后需要做什么呢或者说的我们还需要思考什么呢?
请问大家我们旋转的光标如何不受下载进度的控制呢?
来看下面代码
#include "processbar.h"
#include
#include
const char *lable="|/-";
//version 1
void process()
{
// const int n = 101;
// char buffer[n]; // 这块是编译不过的
char buffer[NUM];
memset(buffer, '', sizeof(buffer));
int cnt = 0;
int n = strlen(lable);
buffer[0] = Head;
while(cnt 100)
{
printf("[%-100s][%3d%%][%c]r", buffer, cnt, lable[cnt%n]);
fflush(stdout);
buffer[cnt++] = Body;
if(cnt 100) buffer[cnt] = Head;
usleep(50000);
}
printf("n");
}
//version 2: 进度是多少,你进度条能知道吗?另外,什么进度?依附于其他应用的,比如下载
char buffer[NUM] = {0};
void process_flush(double rate)
{
static int cnt = 0;
int n = strlen(lable);
if(rate 1.0) buffer[0] = Head;
printf("[33[4;32;44m%-100s33[0m][%.1f%%][%c]r", buffer, rate, lable[cnt%n]);
fflush(stdout);
buffer[(int)rate] = Body;
if((int)rate+1 100) 服务器托管网buffer[(int)(rate+1)] = Head;
if(rate>=100.0) printf("n");
cnt++;
cnt%=n;
进度条不受下载进度的影响 那么我们这时候就在代码的最后两行加上我的上述代码就可以完美解决
这就是不受进度条影响光标自动旋转的代码
#pragma once
#include
#define NUM 103
#define Body '='
#define Head '>'
typedef void (*callback_t)(double);
//version 1
void process();
//version 2
void process_flush(double rate);
服务器托管,北京服务器托管,服务器租用 http://www.fwqtg.net
相关推荐: 记录一次 postgresql 优化案例( volatility 自定义函数无法并行查询 )
同事最近做个金融适配项目,找我看条SQL,告知ORACLE跑1分钟,PG要跑30分钟(其实并没有这么夸张),废话不说,贴慢SQL。 慢SQL(关键信息已经加密): explain analyze SELECT c_qxxxxaode, ‘2023-03-22 …