Windows C++移植到Linux下运行需要怎么做?(以动态甜甜圈为例)

举报
zhangrelay 发表于 2021/07/15 01:51:13 2021/07/15
【摘要】 本文将(https://zhangrelay.blog.csdn.net/article/details/109863427)程序在Linux下运行。 具体版本为Ubuntu 20.04。 程序如下: #include <stdio.h>#include <math.h>#include <cstring>#include <W...

本文将(https://zhangrelay.blog.csdn.net/article/details/109863427)程序在Linux下运行。

具体版本为Ubuntu 20.04。

程序如下:


  
  1. #include <stdio.h>
  2. #include <math.h>
  3. #include <cstring>
  4. #include <Windows.h>
  5. void usleep(__int64 usec)
  6. {
  7. HANDLE timer;
  8. LARGE_INTEGER ft;
  9. ft.QuadPart = -(10 * usec);
  10. timer = CreateWaitableTimer(NULL, TRUE, NULL);
  11. SetWaitableTimer(timer, &ft, 0, NULL, NULL, 0);
  12. WaitForSingleObject(timer, INFINITE);
  13. CloseHandle(timer);
  14. }
  15. int main() {
  16. float A = 0, B = 0;
  17. float i, j;
  18. int k;
  19. float z[1760];
  20. char b[1760];
  21. printf("\x1b[2J");
  22. for (;;) {
  23. memset(b, 32, 1760);
  24. memset(z, 0, 7040);
  25. for (j = 0; j < 6.28; j += 0.07) {
  26. for (i = 0; i < 6.28; i += 0.02) {
  27. float c = sin(i);
  28. float d = cos(j);
  29. float e = sin(A);
  30. float f = sin(j);
  31. float g = cos(A);
  32. float h = d + 2;
  33. float D = 1 / (c * h * e + f * g + 5);
  34. float l = cos(i);
  35. float m = cos(B);
  36. float n = sin(B);
  37. float t = c * h * g - f * e;
  38. int x = 40 + 30 * D * (l * h * m - t * n);
  39. int y = 12 + 15 * D * (l * h * n + t * m);
  40. int o = x + 80 * y;
  41. int N = 8 * ((f * e - c * d * g) * m - c * d * e - f * g - l * d * n);
  42. if (22 > y && y > 0 && x > 0 && 80 > x && D > z[o]) {
  43. z[o] = D;
  44. b[o] = ".,-~:;=!*#$@"[N > 0 ? N : 0];
  45. }
  46. }
  47. }
  48. printf("\x1b[H");
  49. for (k = 0; k < 1761; k++) {
  50. putchar(k % 80 ? b[k] : 10);
  51. A += 0.00004;
  52. B += 0.00002;
  53. }
  54. usleep(30000);
  55. }
  56. return 0;
  57. }

直接暴力编译必然报错如下:

将其更换为 #include <unistd.h> ,并删除如下函数:


  
  1. void usleep(__int64 usec)
  2. {
  3. HANDLE timer;
  4. LARGE_INTEGER ft;
  5. ft.QuadPart = -(10 * usec);
  6. timer = CreateWaitableTimer(NULL, TRUE, NULL);
  7. SetWaitableTimer(timer, &ft, 0, NULL, NULL, 0);
  8. WaitForSingleObject(timer, INFINITE);
  9. CloseHandle(timer);
  10. }

再次编译:

g++ donut.cpp

运行以下看看效果吧?就不做动图了,这个案例只为了说明算法是不分平台的,学习算法对于编程而言才是最重要的!


  
  1. #include <stdio.h>
  2. #include <math.h>
  3. #include <cstring>
  4. #include <unistd.h>
  5. int main() {
  6. float A = 0, B = 0;
  7. float i, j;
  8. int k;
  9. float z[1760];
  10. char b[1760];
  11. printf("\x1b[2J");
  12. for (;;) {
  13. memset(b, 32, 1760);
  14. memset(z, 0, 7040);
  15. for (j = 0; j < 6.28; j += 0.07) {
  16. for (i = 0; i < 6.28; i += 0.02) {
  17. float c = sin(i);
  18. float d = cos(j);
  19. float e = sin(A);
  20. float f = sin(j);
  21. float g = cos(A);
  22. float h = d + 2;
  23. float D = 1 / (c * h * e + f * g + 5);
  24. float l = cos(i);
  25. float m = cos(B);
  26. float n = sin(B);
  27. float t = c * h * g - f * e;
  28. int x = 40 + 30 * D * (l * h * m - t * n);
  29. int y = 12 + 15 * D * (l * h * n + t * m);
  30. int o = x + 80 * y;
  31. int N = 8 * ((f * e - c * d * g) * m - c * d * e - f * g - l * d * n);
  32. if (22 > y && y > 0 && x > 0 && 80 > x && D > z[o]) {
  33. z[o] = D;
  34. b[o] = ".,-~:;=!*#$@"[N > 0 ? N : 0];
  35. }
  36. }
  37. }
  38. printf("\x1b[H");
  39. for (k = 0; k < 1761; k++) {
  40. putchar(k % 80 ? b[k] : 10);
  41. A += 0.00004;
  42. B += 0.00002;
  43. }
  44. usleep(30000);
  45. }
  46. return 0;
  47. }

 








 

文章来源: zhangrelay.blog.csdn.net,作者:zhangrelay,版权归原作者所有,如需转载,请联系作者。

原文链接:zhangrelay.blog.csdn.net/article/details/110206761

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。