本文目錄一覽:
C# 調用C語言介面問題
沒錯就是傳值的問題
最後一個string傳遞不正確,很可能被當作Unicode傳進去了
DllImport屬性里加上
CharSet=CharSet.Ansi
[System.Runtime.InteropServices.DllImport(“Sign.dll”, CharSet=CharSet.Ansi)]
C語言介面的定義與實現
一個模塊有兩部分組成:介面和實現。介面指明模塊要做什麼,它聲明了使用該模塊的代碼可用的標識符、類型和常式,實現指明模塊是如何完成其介面聲明的目標的,一個給定的模塊通常只有一個介面,但是可能會有許多種實現能夠提供介面所指定的功能。每個實現可能使用不同的演算法和數據結構,但是它們都必須符合介面所給出的使用說明。客戶調用程序是使用某個模塊的一段代碼,客戶調用程序導入介面,而實現導出介面。由於多個客戶調用程序是共享介面和實現的,因此使用實現的目標代碼避免了不必要的代碼重複,同時也有助於避免錯誤,因為介面和實現只需一次編寫和調試就可多次使用
實現
一個實現導出一個介面,它定義了必要的變數和函數以提供介面所規定的功能,在C語言中,一個實現是由一個或多個.c文件提供的,一個實現必須提供其導出的介面所指定的功能。實現應包含介面的.h文件,以保證它的定義和介面的聲明時一致的。
Arith_min和Arith_max返回其整型參數中的最小值和最大值:
int Arith_max(int x, int y) {
return x y ? x : y;
}
int Arith_min(int x, int y) {
return x y ? y : x;
}
Arith_div返回y除以x得到的商,Arith_mod返回相應的餘數。當x與y同號的時候,Arith_div(x,y)等價於x/y,Arith_mod(x,y)等價於x%y
當x與y的符號不同的時候,C的內嵌操作的返回值就取決於具體的實現:
eg.如果-13/5=2,-13%5=-3,如果-13/5=-3,-13%5=2
標準庫函數總是向零取整,因此div(-13,2)=-2,Arith_div和Arith_mod的語義同樣定義好了:它們總是趨近數軸的左側取整,因此Arith_div(-13,5)=-3,Arith_div(x,y)是不超過實數z的最大整數,其中z滿足z*y=x。
Arith_mod(x,y)被定義為x-y*Arith_div(x,y)。因此Arith_mod(-13,5)=-13-5*(-3)=2
函數Arith_ceiling和Arith_floor遵循類似的約定,Arith_ceiling(x,y)返回不小於實數商x/y的最小整數
Arith_floor(x,y)返回不超過實數商x/y的最大整數
完整實現代碼如下:
arith.c
抽象數據類型
抽象數據類型(abstract data type,ADT)是一個定義了數據類型以及基於該類型值提供的各種操作的介面
一個高級類型是抽象的,因為介面隱藏了它的表示細節,以免客戶調用程序依賴這些細節。下面是一個抽象數據類型(ADT)的規範化例子–堆棧,它定義了該類型以及五種操作:
stack.h
實現
包含相關頭文件:
#include stddef.h
#include “assert.h”
#include “mem.h”
#include “stack.h”
#define T Stack_T
Stack_T的內部是一個結構,該結構有個欄位指向一個棧內指針的鏈表以及一個這些指針的計數:
struct T {
int count;
struct elem {
void *x;
struct elem *link;
} *head;
};
Stack_new分配並初始化一個新的T:
T Stack_new(void) {
T stk;
NEW(stk);
stk-count = 0;
stk-head = NULL;
return stk;
}
其中NEW是一個另一個介面中的一個分配宏指令。NEW(p)將分配該結構的一個實例,並將其指針賦給p,因此Stack_new中使用它就可以分配一個新的Stack_T
當count=0時,Stack_empty返回1,否則返回0:
int Stack_empty(T stk) {
assert(stk);
return stk-count == 0;
}
assert(stk)實現了可檢查的運行期錯誤,它禁止空指針傳給Stack中的任何函數。
Stack_push和Stack_pop從stk-head所指向的鏈表的頭部添加或移出元素:
void Stack_push(T stk, void *x) {
struct elem *t;
assert(stk);
NEW(t);
t-x = x;
t-link = stk-head;
stk-head = t;
stk-count++;
}
void *Stack_pop(T stk) {
void *x;
struct elem *t;
assert(stk);
assert(stk-count 0);
t = stk-head;
stk-head = t-link;
stk-count–;
x = t-x;
FREE(t);
return x;
}
FREE是另一個介面中定義的釋放宏指令,它釋放指針參數所指向的空間,然後將參數設為空指針
void Stack_free(T *stk) {
struct elem *t, *u;
assert(stk *stk);
for (t = (*stk)-head; t; t = u) {
u = t-link;
FREE(t);
}
FREE(*stk);
}
完整實現代碼如下:
#include stddef.h
#include “assert.h”
#include “mem.h”
#include “stack.h”
#define T Stack_T
struct T {
int count;
struct elem {
void *x;
struct elem *link;
} *head;
};
T Stack_new(void) {
T stk;
NEW(stk);
stk-count = 0;
stk-head = NULL;
return stk;
}
int Stack_empty(T stk) {
assert(stk);
return stk-count == 0;
}
void Stack_push(T stk, void *x) {
struct elem *t;
assert(stk);
NEW(t);
t-x = x;
t-link = stk-head;
stk-head = t;
stk-count++;
}
void *Stack_pop(T stk) {
void *x;
struct elem *t;
assert(stk);
assert(stk-count 0);
t = stk-head;
stk-head = t-link;
stk-count–;
x = t-x;
FREE(t);
return x;
}
void Stack_free(T *stk) {
struct elem *t, *u;
assert(stk *stk);
for (t = (*stk)-head; t; t = u) {
u = t-link;
FREE(t);
}
FREE(*stk);
}
關於C語言的函數和介面問題
函數應該就是介面了 函數返回值 函數名和函數參數 c語言可以寫dll可以把其中的函數導出
C語言函數介面問題!
int inquire_information(struct Address_list User[]);
void output_information(int i,struct Address_list User[]);
這兩個函數的聲明中,Address_list的L都是小寫,
而main函數中struct Address_List User[50],*p=User;這一行聲明,Address_List的L是大寫的。
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/244171.html