Linux中vscode编程,小白入门喂饭级教程

确保Ubuntu联网

因为后面安装VScode需要从互联网下载。

安装GCC

在桌面空白处右键->打开终端

执行命令:gcc -v

在最后一行可以看到gcc version 7.5.0

如果提示Command ‘gcc’ not found,就查一下如何安装gcc,先把gcc安装好。

安装VScode

进入Ubuntu后,点击左下角的“Ubuntu软件”图标,打开Ubuntu软件管理界面。

点右上角的放大镜,在出现的搜索框中输入“vscode”,回车。在搜索结果中,点击蓝色图标的“code”。

点“安装”。

安装完成后,在左下角出现VScode的蓝色图标,点该图标。

在打开的VScode界面中,点击左侧栏的“扩展”图标

在顶部搜索框中输入“C/C++”,选中第一个结果 ,点击“安装”。

同理,安装

在顶部搜索框中输入“chinese”,选中第一个结果 ,点击“安装”。

新建文件夹(VScode中一个文件夹就是一个工程)

在桌面新建文件夹“MyTest1”(可自定义)。

在VScode中点击“资源管理器”图标 ,再点“打开文件夹”,选择“MyTest1”。

点“是,我信任此作者”。

点击新建文件,在出现的输入框中输入“main.c”(可自定义)。

在右侧输入代码:

#include <stdio.h>

void main()

{

       printf(“hello world\n”);

}

点击右上角的运行和调试 ,在出现的下拉框中选“C/C++: gcc构建和调试活动文件”。

在代码下方的终端窗口中出现“hello world”,可见测试代码已成功执行。

如果出现下面报错,点“中止”,并检查代码的错误。

如果没有出现报错,终端窗口中也没有出现“hello world”,就再点一下

添加函数

在main.c中添加函数AddFunc,实现简单的加法。

添加文件

将AddFunc分离到单独的c文件中

新建“commonfunc.c”文件,将AddFunc函数剪切过来。

如果在选中commonfunc.c时,点运行和调试 ,则会报错“对main未定义的引用”。

因此,一定要先选中包含main函数的c文件,再点编译运行。

选中main.c,再点运行和调试,提示implicit-function-deciaration AddFunc,就是找不到AddFunc函数。

新建commonfunc.h文件,在其中声明AddFunc函数。

在main.c中添加include。

修改tasks.json文件,将“args”中的”${file}”修改为”${fileDirname}/*.c”

点运行和调试,终端输出 “sum: 10”,可见程序执行成功。

多线程

修改main.c为

#include <stdio.h>

#include  "commonfunc.h"

#include <pthread.h>

void* thread_func1(void* args)

{

    for(int i=0;i<5;i++)

       {

        printf(">>>thread_func1: %d\n",i);

        sleep(1);

    }

}

void main()

{

    int c = AddFunc(2,8);

    printf("sum:%d\n",c);

    ///创建线程1/

       pthread_t tid1;

       int res1 = pthread_create(&tid1,NULL,&thread_func1,(void*)"thread1");

       if(res1!=0)

       {

              printf("创建线程1 failed\n");

          exit(1);

       }

       printf("创建线程1 ok\n");

       for(int i=0;i<10;i++)

              sleep(1);

}

点运行和调试,终端提示“对pthread_create未定义的引用”,是由于目前gcc的编译参数中没有链接pthread库。

修改tasks.json文件,在“args”中最后添加”-lpthread”,注意:必须加在最后。

注意:上一个参数的结尾要加逗号。

点运行和调试,终端输出5次 “>>>thread_func1”,可见子线程执行成功。

### MySQL 常用内置函数汇总 #### 数学运算函数 MySQL 提供了一系列用于数学运算的函数,例如 `ABS()`、`CEIL()` 和 `FLOOR()` 等。这些函数可以帮助开发者轻松完成各种数值计算任务[^1]。 - **ABS(x)**:返回参数 x 的绝对值。 - **CEIL(x)** 或者 **CEILING(x)**:返回大于等于 x 的最小整数。 - **FLOOR(x)**:返回小于等于 x 的最大整数。 ```sql SELECT ABS(-5); -- 输出 5 SELECT CEIL(3.14); -- 输出 4 SELECT FLOOR(3.98); -- 输出 3 ``` #### 字符串处理函数 字符串处理是数据库操作中的重要部分,MySQL 支持多种字符串函数以便于数据管理和分析。 - **CONCAT(str1, str2,...)**:连接多个字符串并返回结果。 - **LOWER(str)** / **LCASE(str)**:将字符串转换成小写形式。 - **UPPER(str)** / **UCASE(str)**:将字符串转换成大写形式。 ```sql SELECT CONCAT('Hello', ' ', 'World'); -- 输出 Hello World SELECT LOWER('HELLO WORLD'); -- 输出 hello world SELECT UPPER('hello world'); -- 输出 HELLO WORLD ``` #### 时间和日期函数 时间和日期的操作在实际应用中非常频繁,因此 MySQL 设计了许多专门针对时间戳管理的功能性函数[^4]。 - **NOW()**:获取当前系统日期和时间。 - **CURDATE()**:仅返回今天的日期部分。 - **CURTIME()**:只显示现在的时间部分。 - **DATE_SUB(date, INTERVAL expr unit)**:从指定日期减去一定时间段后的结果。 ```sql SELECT NOW(); -- 当前时刻 SELECT CURDATE(); -- 只有日期 SELECT DATE_SUB(CURDATE(), INTERVAL 7 DAY); -- 计算一周之前的日期 ``` #### 杂项功能函数 除了上述类别外还有一些其他用途广泛的工具型方法值得了解: - **PASSWORD(str)**:生成哈希值以保护敏感字段比如密码存储安全[^2]。 - **BENCHMARK(count,expr)**:测试表达式性能评估其运行效率[^3]。 ```sql -- 创建加密版本的输入字符串 SELECT PASSWORD('test'); -- 测量某个简单查询耗时情况 SELECT BENCHMARK(1000000, MD5(RAND())); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值