三、C++ 链接器 linker

cilinking:从C++源码到可执行二进制的过程。compile文件之后进行链接,找到每个符号、函数的位置,并将其链接在一起

每个文件被编译成一个独立的.obj文件作为translation unit,这些文件无法自主沟通。写一个程序使用到了多个文件时,使用linker将这些文件链接到一个程序。(<——链接器的工作)。

即使没有外部文件里的函数(仅有一个文件),应用程序为了直到入口点在哪(main函数在哪,程序运行时从main函数开始)

编译有两个阶段:编译与链接

区分方法:ctrl+F7 或 build(编译)文件,仅有编译发生,未发生链接

build整个项目之后,或F5运行时 先编译后链接

编译器complier处理语法错误 C开头, 表示编译阶段发生的错误

链接器linker处理链接错误 LNK开头, 表示链接阶段发生的错误

令Source Files文件夹下仅有Math.cpp文件,

Math.cpp

#include <iostream>

void Log(const char* message) 
{
	std::cout << message << std::endl;	
}

int Multiply(int a, int b)
{
	Log("Multiply");
	return a * b;
}

 此时build整个项目会报错LINK:fatal error LNK1561:entry point must be defined

        原因:缺少主函数

 .exe文件必要要有一个切入点

该切入点不一定非得是main函数,但是必须要有切入点

在Math.cpp函数中添加main函数,编译整个项目成功(linker)生成.exe文件,此时Math.cpp

#include <iostream>

void Log(const char* message) 
{
	std::cout << message << std::endl;	
}

int Multiply(in
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要连接SQL Server数据库,需要使用ODBC驱动程序。ODBC(Open Database Connectivity)是一种标准的数据库访问方式,可以让不同的应用程序通过统一的接口来访问各种数据库。在Dev-C++中,可以使用ODBC API来访问SQL Server数据库。 以下是连接SQL Server数据库的步骤: 1. 安装ODBC驱动程序。可以从Microsoft官网下载ODBC驱动程序。 2. 在Dev-C++中创建一个新的项目。 3. 在项目设置中,选择“Linker”选项卡,将odbc32.lib和user32.lib添加到链接附加库中。 4. 在代码中包含头文件#include <windows.h>和#include <sql.h>。 5. 使用SQLAllocHandle函数分配句柄,使用SQLDriverConnect函数连接到数据库。 6. 使用SQLExecDirect函数执行SQL语句。 以下是一个示例代码,可以连接到SQL Server数据库并执行SQL查询: ```c++ #include <windows.h> #include <sql.h> int main() { SQLHENV env; //环境句柄 SQLHDBC dbc; //连接句柄 SQLHSTMT stmt; //语句句柄 SQLRETURN ret; //返回值 //分配环境句柄 ret = SQLAllocHandle(SQL_HANDLE_ENV, SQL_NULL_HANDLE, &env); //设置环境属性,告诉ODBC版本 ret = SQLSetEnvAttr(env, SQL_ATTR_ODBC_VERSION, (SQLPOINTER)SQL_OV_ODBC3, 0); //分配连接句柄 ret = SQLAllocHandle(SQL_HANDLE_DBC, env, &dbc); //连接数据库 ret = SQLDriverConnect(dbc, NULL, "DRIVER={SQL Server};SERVER=myServerName;DATABASE=myDataBaseName;UID=myUsername;PWD=myPassword;", SQL_NTS, NULL, 0, NULL, SQL_DRIVER_COMPLETE); if (ret == SQL_SUCCESS || ret == SQL_SUCCESS_WITH_INFO) { //执行SQL语句 ret = SQLAllocHandle(SQL_HANDLE_STMT, dbc, &stmt); ret = SQLExecDirect(stmt, "SELECT * FROM myTable", SQL_NTS); //处理结果 //... } //释放句柄 SQLFreeHandle(SQL_HANDLE_STMT, stmt); SQLDisconnect(dbc); SQLFreeHandle(SQL_HANDLE_DBC, dbc); SQLFreeHandle(SQL_HANDLE_ENV, env); return 0; } ``` 在连接字符串中,需要替换myServerName、myDataBaseName、myUsername和myPassword为实际的SQL Server服务名称、数据库名称、用户名和密码。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值