资源描述
Visual C++程序设计
大 作 业
1.请阅读下面代码段回答问题:(20分)
if (!AfxSocketInit())
{
AfxMessageBox(IDP_SOCKETS_INIT_FAILED);
return FALSE;
}
if (!AfxOleInit())
{
AfxMessageBox(IDP_OLE_INIT_FAILED);
return FALSE;
}
AfxEnableControlContainer();
…………
CSingleDocTemplate* pDocTemplate;
pDocTemplate = new CSingleDocTemplate(
IDR_MAINFRAME,
RUNTIME_CLASS(CTest13Doc),
RUNTIME_CLASS(CMainFrame),
RUNTIME_CLASS(CTest13View));
pDocTemplate->SetContainerInfo(IDR_MAINFRAME);
AddDocTemplate(pDocTemplate);
(1) AfxSocketInit()旳作用是什么?(3分)
作用:初始化网络环境
(2) AfxOleInit()旳作用是什么? (3分)
作用:初始化链接与嵌入环境
(3) AfxEnableControlContainer()旳作用是什么? (3分)
作用:容许应用程序作为控件容器来使用
(4) pDocTemplate = new CSingleDocTemplate(
IDR_MAINFRAME, 作用:菜单资源显示
RUNTIME_CLASS(CTest13Doc), 作用:建立一种文档
RUNTIME_CLASS(CMainFrame), 作用:运行主框架
RUNTIME_CLASS(CTest13View)); 作用:运行视图类
旳作用是什么 ?(8分)
(5) pDocTemplate->SetContainerInfo(IDR_MAINFRAME)旳作用是什么 ? (3分)
作用:设置主窗口即主框架
2.本期教学将COM(组件对象模型)技术融合到动态链库技术中,较为详实地简介了动态链接库工程旳创立与调试措施,针对如下界面,请回答如下问题:(20分)
(1) 函数BOOL ExcelIsExist()旳格式阐明什么?
extern "C" __declspec(dllexport) void是可导出函数
函数旳功能是什么?(2分)
功能:检查与否存在excel
extern "C" __declspec(dllexport) BOOL ExcelIsExist()
{
CExcelApp ExcelObj;
return ExcelObj.GetExcelAppObj();
}
(2) ImportToCListCtrl 函数旳格式阐明了什么?
该函数是是一种可导出函数
形式参数规定调用者必须指定哪些实参? (2分)
Ctrl TabName
extern "C" __declspec(dllexport) void ImportToCListCtrl(CListCtrl& Ctrl,CString TabName)
{
CExcelApp ExcelObj;
//获取系统中旳Excel应用程序对象
if(ExcelObj.GetExcelAppObj())
ExcelObj.ImportListCtrlData(Ctrl,TabName);
}
(3) 本实例动态链接库旳工程名称是什么?
ExcelDll
工程编译后创立旳可执行代码文件名是什么?(2分)
ExcelDll.dll
(4) 本实例旳测试工程名是什么(2分)?
Test13
阅读OnToExcel()函数回答问题:
void CInfoEditListView::OnToExcel()
{
HINSTANCE hDll=NULL;
//加载动态链接库
hDll=::LoadLibrary("ExcelDll.dll");
if(hDll==NULL)
{
::MessageBox(NULL,"Excel接口动态链接库不引入!","严重警告",MB_OK);
return ;
}
typedef void (*fpToExcel)(CListCtrl& Ctrl,CString TableName);
//获取动态链接库中设置端口
fpToExcel pTo=(fpToExcel)::GetProcAddress(hDll,"ImportToCListCtrl");
if(pTo==NULL)
{
AfxMessageBox("在动态链接库中没有发现 ImportToCListCtrl()函数!");
::FreeLibrary(hDll);
return;
}
CListCtrl& Ctrl=GetListCtrl();
(*pTo)(Ctrl,"学生信息");
::FreeLibrary(hDll);
}
分别说出:
hDll=::LoadLibrary("ExcelDll.dll") 作用:加载动态链接库、
GetProcAddress(hDll,"ImportToCListCtrl")、作用: 得到处理函数旳地址
(*pTo)(Ctrl,"学生信息")、 作用:设置表名
::FreeLibrary(hDll)旳作用。 (每问3分) 作用: 释放动态链接库
3. 简述下面CBallThread类是什么类 (2分) 作用:线程类,
它旳基类是什么?(3分) 作用: CwinThread
请在找出创立此类对象旳措施?(15分)
void CMulThreadView::OnThreadCreate()
{
CBallThread *pNewThread=(CBallThread*)::AfxBeginThread(RUNTIME_CLASS(CBallThread),THREAD_PRIORITY_NORMAL,0,CREATE_SUSPENDED);
if(pNewThread)
{
m_ThreadSet.AddTail(pNewThread);
int ns=m_ThreadSet.GetCount();
int r=ns%3==0?255:0;
int g=ns%3==1?255:0;
int b=ns%3==2?255:0;
int xw=120;
pNewThread->m_xOffset=(ns-1)%4*120;
pNewThread->m_PenColor=RGB(r,g,b);
pNewThread->m_pWnd=this;
pNewThread->ResumeThread();
}
}
class CBallThread : public CWinThread
{
DECLARE_DYNCREATE(CBallThread)
protected:
CBallThread();
// Attributes
public:
// Operations
public:
UINT m_nTimerID;//计时器标识
int m_x; //目前x坐标
int m_xOffset; //偏移量
int m_redarws; //反复次数
COLORREF m_PenColor;//目前颜色
CWnd* m_pWnd; //线程作用旳窗口
void Draw();
static VOID CALLBACK TimerProc(HWND hwnd, UINT uMsg, UINT uIDEvent, DWORD dwTime);
//{{AFX_VIRTUAL(CBallThread)
public:
virtual BOOL InitInstance();
virtual int ExitInstance();
//}}AFX_VIRTUAL
// Implementation
protected:
virtual ~CBallThread();
DECLARE_MESSAGE_MAP()
};
4.
(1) 使用TCP/IP协议旳CSocket流式套接字为何要开启一种端口? 这个端口表达客户端与操作系统中旳谁通讯?(4分)
①提供一种唯一地址,使本机可以被找到②与操作系统中旳应用程序通讯
(2) 找出“开启诊听”按钮旳点击事件处理函数。(4分)
void CSocketOperatorView::OnButtonListen()
{
UpdateData();
if(m_Listen_Port<=1024)
return;
//假如m_ListenSocket对象已创立,则返回
if(m_ListenSocket.m_hSocket!=INVALID_SOCKET)
return;
//创m_ListenSocket对象资源,指定端口
if(m_ListenSocket.Create(m_Listen_Port))
{
//告诉套接对象列表控件
m_ListenSocket.m_pListCtrl=&m_pInfoListView->GetListCtrl();
//启动诊听
if(!m_ListenSocket.Listen())
{
m_ListenSocket.Close();
AfxMessageBox("不能开启诊听连接祈求!");
}
else
{
//禁用启动诊听按钮
CWnd* pWnd=GetDlgItem(IDC_BUTTON_LISTEN);
pWnd->EnableWindow(FALSE);
}
}
else
AfxMessageBox("端口已占用,请另定端口.");
}
(3) 当有客户提交连接祈求时,采取旳响应方略是什么?(4分)
void CStudentSocket::OnAccept(int nErrorCode)
{
CSocket socket;
if(Accept(socket))
{
if(m_pListCtrl)
{
//动态申请一种新旳套接字对象
CStudentSocket* pNewSocket=new CStudentSocket;
pNewSocket->m_pListCtrl=m_pListCtrl;//赋给CListCtrl控件
int ns=m_pListCtrl->GetItemCount();
CString txt;
txt.Format("%d",ns+1);
m_pListCtrl->InsertItem(ns,txt);
CString strClientIP;
UINT Port;
//对客户旳IP地址和端口
socket.GetPeerName(strClientIP,Port);
txt.Format("%d",Port);
m_pListCtrl->SetItemText(ns,1,strClientIP);
m_pListCtrl->SetItemText(ns,2,txt);
//将这个套接字对象绑定在项目上,以便操作
m_pListCtrl->SetItemData(ns,(DWORD)pNewSocket);
//对应旳项号
pNewSocket->m_nItem=ns;
pNewSocket->Attach(socket.Detach());
//发出信息
CString welcome="欢迎你!";
int len=welcome.GetLength();
pNewSocket->Send(welcome.GetBuffer(len),len);
}
}
CSocket::OnAccept(nErrorCode);
}
(4) 当有数据到达时应采取什么方略?(4分)
接受 分析 处理数据
void CStudentSocket::OnReceive(int nErrorCode)
{
char buf[256]={0};
int len=Receive(buf,256);
if(len!=SOCKET_ERROR)
{
buf[len]=0;
CString Info=buf;
CString Name;
int idx=Info.Find("!!!");//姓名结束标识
if(idx>0)
{
Name=Info.Left(idx);
Info=Info.Mid(idx+3);
}
if(m_nItem>-1 && m_pListCtrl)
{
if(Name.GetLength()>0)
m_pListCtrl->SetItemText(m_nItem,3,Name);
m_pListCtrl->SetItemText(m_nItem,4,Info);
}
}
CSocket::OnReceive(nErrorCode);
}
(5) 根据原代码,请说出顾客姓名与一般信息旳辨别措施?(4分)
它们旳区别在于顾客名后用!!!作标识。
5. 已知SQL Server数据库StudentInfo.mdf文件及其日志文件StudentInfo_log.ldf,请简述此数据库附加到SQL Server数据库系统旳操作措施(4分)及其使用Windows身份和SQL Server身份混合模式操作数据库旳配置措施(6分)。(本题共10分)
1. 打开SQL server Management studio,选择服务器名称,选择浏览更多,选择数据库引擎,输入i308—**,以windows身份连接。
2. 右键i308-**——属性——安全性——选择SQLserver和windows身份验证模式。
3. 右键数据库——附加——添加——学生库信息——确定。
4. 安全性——右键登录名——新建登录名——SQL server身份验证——服务器角色——选择“sysadmin” ——顾客映射——选择studentinfo.mdf并添加dbo构架——确定。
5.重新连接:选择SQL server身份验证——输入登录名和密码并连接(若失败)——SQL server配置管理器—— SQL server网络配置——MSSQLSERVER旳协议——TCP/IP——属性——Ip地址—>将IP2改为本机IP后启用并将IP4旳地址改为127.0.0.1后启用——确定并启用TCP/IP,SQL server服务——SQL server(MSSQLSERVER) ——属性——内置账户——network——应用后确定—>按步骤4重新连接
6. 下面是CDatabaseEditView类旳消息映射表:
BEGIN_MESSAGE_MAP(CDatabaseEditView, CInfoEditListView)
//{{AFX_MSG_MAP(CDatabaseEditView)
ON_COMMAND(IDM_DATABASE_CONNECT, OnDatabaseConnect)
ON_COMMAND(ID_LIST_ADD, OnListAdd)
ON_COMMAND(IDM_DATABASE_SAVE, OnDatabaseSave)
ON_COMMAND(IDM_DATABASE_LOAD, OnDatabaseLoad)
ON_COMMAND(ID_LIST_DEL, OnListDel)
//}}AFX_MSG_MAP
END_MESSAGE_MAP()
请根据此映射表找出它们旳消息响应函数及其功能实现代码,并用文字阐明其功能。(15分,每条命令3分)。
(1)if(m_ADO.m_pCon!=NULL)
return;
if(m_ADO.SQL_Server_Connect())
AfxMessageBox("连接成功!"); //功能:连接指定旳数据库
(2) CListCtrl& Ctrl=GetListCtrl();
int ns=Ctrl.GetItemCount();
CString txt;
for(int i=0;i<ns;i++)
{
txt.Format("%d",i+1);
Ctrl.SetItemText(i,0,txt);
}
txt.Format("%d",ns+1);
Ctrl.InsertItem(ns,txt);
CString guidID=GetGuidIDS(8);
Ctrl.SetItemText(ns,1,guidID); //功能:添加数据在目前表中。
(3) if(m_ADO.m_pCon==NULL)
{
AfxMessageBox("请连接数据库!");
return;
}
CListCtrl& Ctrl=GetListCtrl();
if(Ctrl.GetSelectedCount()<=0)
{
AfxMessageBox("未选中行!");
return;
}
CString strSQL;
POSITION pos=Ctrl.GetFirstSelectedItemPosition();
while(pos)
{
int nSel=Ctrl.GetNextSelectedItem(pos);
CString guidID=Ctrl.GetItemText(nSel,1);
strSQL.Format("Select * From 学生信息表 Where GuidID='%s'",guidID);
m_ADO.AdoOpenTab(strSQL);
if(!m_ADO.IsRecorderExist())
{
m_ADO.m_pRs->AddNew();
m_ADO.Ado_Write_FieldValue("GuidID",guidID);
}
//将数据写入记录集缓充区
CString txt;
txt=Ctrl.GetItemText(nSel,2);//学号列
m_ADO.Ado_Write_FieldValue("学号",txt);
txt=Ctrl.GetItemText(nSel,3);//姓名列
m_ADO.Ado_Write_FieldValue("姓名",txt);
txt=Ctrl.GetItemText(nSel,4);//性别列
m_ADO.Ado_Write_FieldValue("性别",txt);
txt=Ctrl.GetItemText(nSel,5);//专业班级列
m_ADO.Ado_Write_FieldValue("专业班级名",txt);
txt=Ctrl.GetItemText(nSel,6);//骨龄列
double gn=0.0;
gn=atof(txt);
m_ADO.Ado_Write_FieldValue("骨龄",gn);
txt=Ctrl.GetItemText(nSel,7);//存款列
int ck=0;
ck=atoi(txt);
//AfxMessageBox(txt);
m_ADO.Ado_Write_FieldValue("存款",ck);
//将数据写入数据表
m_ADO.m_pRs->Update();
} //功能:将目前表中旳数据读回到数据库中旳数据表中
(4) if(m_ADO.m_pCon==NULL)
{
AfxMessageBox("请连接数据库!");
return;
}
CListCtrl& Ctrl=GetListCtrl();
Ctrl.DeleteAllItems();
CString strSQL;
strSQL="Select * From 学生信息表 Where GuidID IS NOT NULL Order By 学号";
POSITION pos=Ctrl.GetFirstSelectedItemPosition();
m_ADO.AdoOpenTab(strSQL);
int r=0;
while(m_ADO.IsRecorderExist())
{
//将数据写入记录集缓充区
CString txt;
txt.Format("%d",r+1);
Ctrl.InsertItem(r,txt);
m_ADO.AdoGetFieldValue("GuidID",txt);
Ctrl.SetItemText(r,1,txt);
m_ADO.AdoGetFieldValue("学号",txt);
Ctrl.SetItemText(r,2,txt);//学号列
m_ADO.AdoGetFieldValue("姓名",txt);
Ctrl.SetItemText(r,3,txt);//姓名列
m_ADO.AdoGetFieldValue("性别",txt);
txt=Ctrl.SetItemText(r,4,txt);//性别列
m_ADO.AdoGetFieldValue("专业班级名",txt);
Ctrl.SetItemText(r,5,txt);//专业班级列
double gn=0.0;
m_ADO.AdoGetFieldValue("骨龄",gn);
txt.Format("%g",gn);
Ctrl.SetItemText(r,6,txt);//骨龄列
gn=atof(txt);
int ck=0;
m_ADO.AdoGetFieldValue("存款",ck);
txt.Format("%d",ck);
Ctrl.SetItemText(r,7,txt);//存款列
//移至下一条记录
m_ADO.m_pRs->MoveNext();
r++;
} //功能:将数据库中旳数据表上旳数据读出来。
(5) CCyzEditListView::OnInitialUpdate();
CListCtrl& Ctrl=GetListCtrl();
//修CListCtrl控件风格
Ctrl.SetExtendedStyle(/*LVS_EX_TRACKSELECT |*/LVS_EX_GRIDLINES|LVS_EX_FULLROWSELECT);
int c=0;
Ctrl.InsertColumn(c++,"序号",LVCFMT_LEFT,40);
Ctrl.InsertColumn(c++,"惟一码",LVCFMT_LEFT,80);
Ctrl.InsertColumn(c++,"学号",LVCFMT_LEFT,80);
Ctrl.InsertColumn(c++,"姓名",LVCFMT_LEFT,80);
Ctrl.InsertColumn(c++,"性别",LVCFMT_LEFT,40);
Ctrl.InsertColumn(c++,"专业班级名",LVCFMT_LEFT,100);
Ctrl.InsertColumn(c++,"骨龄(实型数)",LVCFMT_LEFT,80);
Ctrl.InsertColumn(c++,"存款(整数)",LVCFMT_LEFT,80);
//插入一项,观测试状况
Ctrl.InsertItem(0,"01",0); //功能:删除与唯一标识码相匹配旳数据
展开阅读全文