go语言如何实现cls清屏

Python015

go语言如何实现cls清屏,第1张

操作方法:

#include<stdlib.h>

调用system("cls")清屏,

清屏后重新输出欢迎内容。

或者:

#include<conio.h>

clrscr()

C++ 也可用C的函数:

system("命令")

DOS清屏命令是 CLS, 所以用:

system("CLS")

unix / linux 清屏命令是 clear, 所以用:

system("clear")

退出一层的命令是 exit, (退出最后一层,窗就没了)。

system("exit")

设置可同时执行的逻辑Cpu数量,默认和硬件的线程数一致而不是核心数,可以通过调用GOMAXPROCS(-1)来获取当前逻辑Cpu数最好在main函数之前设置它,GOMAXPROCS同时也是go的环境变量之一。

return结束当前函数,并返回指定值;runtime.Goexit结束当前goroutine,其他的goroutine不受影响,主程序也一样继续运行;os.Exit会结束当前程序,不管你三七二十一;暂停当前goroutine,使其他goroutine先行运算。只是暂停,不是挂起,当时间片轮转到该协程时,Gosched()后面的操作将自动恢复。还没等到子协程执行,主协程就已经执行完退出了,子协程将不再执行,所以打印的全部是主协程的数据。当然,实际上这个执行结果也是不确定的,只是大概率出现以上输出,因为主协程和子协程间并没有绝对的顺序关系。在打印goroutine1之前,主协程调用了runtime.Gosched()方法,暂停了主协程。子协程获得了调度,从而先行打印了goroutine2。主协程不是一定要等其他协程执行完才会继续执行,而是一定时间。如果这个时间内其他协程没有执行完,那么主协程将继续执行,立即终止当前协程,不会影响其它协程,且终止前会调用此协程声明的defer方法。由于Goexit不是panic,所以recover捕获的error会为nil。当main方法所在主协程调用Goexit时,Goexit不会return,所以主协程将继续等待子协程执行,当所有子协程执行完时,程序报错deadlock。

你的代码是想把front到rear的值全部输出

但是你下面的操作自己检查一下没有改变front的值,也没有改变rear的值,所以front!=rear是死循环

如果好一点的话

void printQueue(LinkQueue *Q)/*依次输出队列*/

{

if(Q->front==Q->rear)

{

printf("队列为空")

exit(1)

}

while(Q->front!=Q->rear)/*老师告诉我说是这里的while是死循环,为什么是死循环呢,不是很懂,请细说。请帮我改为正确的代码,谢谢。*/

{

printf("%d, ", Q->front->data)

Q->front=Q->front->next

}

//exit(0)

}试试可不可以,不行再追问