- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在尝试通过 wifi 连接将数据发送到接收器以进行实验。我设法使用适用于 wifi 的 Windows API Native 将卡连接到接收器。
我将卡的 GUID 存储在 pIfInfo 指针 (PWLAN_INTERFACE_INFO) 中并提取它以创建允许我在连接上写入的句柄 (WifiAcess)。
然后,如果我运行它,我会在 WriteFile 函数上收到错误 ERROR_INVALID_PARAMETER,无论是否在 envois 之前进行 (void*) 转换。
嗯,我的问题是,我不知道哪个参数无效
DWORD bytesSend;
char *buffer ;
unsigned int nbChar ;
要发送的数据
int headerData[4] = {85,0,11,0};
int ServosData[6] = {100,100,0,100,0,0};
BYTE * envois = new BYTE[11];
envois[0] = headerData[0] ;
envois[1] = headerData[1] ;
envois[2] = headerData[2] ;
envois[3] = headerData[3] ;
envois[4] = ServosData[0] ;
envois[5] = ServosData[1] ;
envois[6] = ServosData[2] ;
envois[7] = ServosData[3] ;
envois[8] = ServosData[4] ;
envois[9] = ServosData[5] ;
校验和
for(int i = 0 ; i<10;i++)
{
envois[10] = envois[10] + envois[i] ;
}
envois[10] = envois[10]%256 ;
nbChar = 11 ;
HANDLE WifiAcess = INVALID_HANDLE_VALUE;
LPCSTR AcessGUID ;
char GuidString2Char[46] ;
char DefChar = ' ';
bool sendtOk = false ;
这里我们从 wifi 连接获取 Wlan 卡的 GUID
sprintf(GuidString2Char, "\\\\.\\{%08lX-%04hX-%04hX-%02hhX%02hhX-%02hhX%02hhX%02hhX%02hhX%02hhX%02hhX}",
pIfInfo->InterfaceGuid.Data1,
pIfInfo->InterfaceGuid.Data2,
pIfInfo->InterfaceGuid.Data3,
pIfInfo->InterfaceGuid.Data4[0],
pIfInfo->InterfaceGuid.Data4[1],
pIfInfo->InterfaceGuid.Data4[2],
pIfInfo->InterfaceGuid.Data4[3],
pIfInfo->InterfaceGuid.Data4[4],
pIfInfo->InterfaceGuid.Data4[5],
pIfInfo->InterfaceGuid.Data4[6],
pIfInfo->InterfaceGuid.Data4[7]);
将翻译后的 GUID 放入 LPCSTR 中
AcessGUID = GuidString2Char ;
然后创建句柄
WifiAcess = CreateFile(
AcessGUID ,
GENERIC_READ | GENERIC_WRITE,
FILE_SHARE_READ ,
NULL,
OPEN_EXISTING,
FILE_ATTRIBUTE_NORMAL | FILE_FLAG_OVERLAPPED,
(HANDLE)INVALID_HANDLE_VALUE); // NULL
检查错误
if(WifiAcess == INVALID_HANDLE_VALUE)
{
dwResult = GetLastError();
switch(dwResult)
{
case ERROR_FILE_NOT_FOUND :
wprintf(L"\t\t\CreateFile ERROR_FILE_NOT_FOUND\n");
break ;
default :
wprintf(L"\t\t\CreateFile default\n");
break;
}
}
else { wprintf(L"\t\t\CreateFile Success\n"); }
尝试在WifiAccess句柄上写入缓冲区
sendtOk = WriteFile(WifiAcess, envois, nbChar, &bytesSend, NULL) ;
if(!sendtOk)
{
wprintf(L"\n\t\t\tEcheque de l envois : %d bytes envoyes\n\n", bytesSend);
dwResult = GetLastError();
switch(dwResult)
{
///////////////////////////////////////////////////////////////////////////////////////////////
case ERROR_INVALID_PARAMETER :
wprintf(L"\t\t\WriteFile ERROR_INVALID_PARAMETER\n");
break ;
///////////////////////////////////////////////////////////////////////////////////////////////
case S_FALSE :
wprintf(L"\t\t\WriteFile S_FALSE\n");
break ;
case E_UNEXPECTED :
wprintf(L"\t\t\WriteFile E_UNEXPECTED\n");
break ;
default :
wprintf(L"\t\t\WriteFile default with dword : 0x%x \n", dwResult);
break;
}
}else
{
wprintf(L"Data Sendt\n\n");
}
最佳答案
好吧,我发现哪里出了问题,不能使用串行 com 的类比,而是使用 winsock 类:
http://msdn.microsoft.com/en-us/library/windows/desktop/ms738545(v=vs.85).aspx
============================================= ================================================ ====初始化:
WSADATA wsaData;
int iResult;
// Initialize Winsock
iResult = WSAStartup(MAKEWORD(2,2), &wsaData);
if (iResult != 0) {
printf("WSAStartup failed: %d\n", iResult);
return 1;
}
// ======================================================================================================
// Création du Socket :
struct addrinfo *result = NULL,
*ptr = NULL,
hints;
ZeroMemory( &hints, sizeof(hints) );
hints.ai_family = AF_INET ;
hints.ai_socktype = SOCK_STREAM;
hints.ai_protocol = IPPROTO_TCP;
#define DEFAULT_PORT "27015"
// Resolve the server address and port
iResult = getaddrinfo("10.10.100.254","8899" , &hints, &result); //"10.10.100.254" DEFAULT_PORT "8899"
if (iResult == 0) {
printf("\n\t\tgetaddrinfo, adresse trouvee\n");
struct addrinfo *res = NULL;
int error;
for (res = result; res != NULL; res = res->ai_next)
{
char hostname[NI_MAXHOST] = "";
error = getnameinfo(res->ai_addr, res->ai_addrlen, hostname, NI_MAXHOST, NULL, 0, 0);
if (error != 0)
{
fprintf(stderr, "error in getnameinfo: %s\n", gai_strerror(error));
continue;
}
if (*hostname != '\0')
{
printf("hostname: %s\n", hostname);
ptr=res;
}
}
}else
{
printf("getaddrinfo failed: %d\n", iResult);
WSACleanup();
return 1;
}
SOCKET ConnectSocket = INVALID_SOCKET;
// Attempt to connect to the first address returned by
// the call to getaddrinfo
// Create a SOCKET for connecting to server
ConnectSocket = socket(ptr->ai_family, ptr->ai_socktype, ptr->ai_protocol);
if (ConnectSocket == INVALID_SOCKET) {
printf("Error at socket(): %ld\n", WSAGetLastError());
freeaddrinfo(result);
WSACleanup();
return 1;
}
// ======================================================================================================
// Connect to a socket :
iResult = connect( ConnectSocket, ptr->ai_addr, (int)ptr->ai_addrlen);
if (iResult == SOCKET_ERROR) {
wprintf(L"socket function failed with error: %ld\n", WSAGetLastError());
switch(WSAGetLastError())
{
case WSAEHOSTUNREACH:
wprintf(L"\n\t\tNo route to host. A socket operation was attempted to an unreachable host. See WSAENETUNREACH.\n");
break;
default:
break;
}
closesocket(ConnectSocket);
ConnectSocket = INVALID_SOCKET;
}
// Should really try the next address returned by getaddrinfo
// if the connect call failed
// But for this simple example we just free the resources
// returned by getaddrinfo and print an error message
freeaddrinfo(result);
if (ConnectSocket == INVALID_SOCKET) {
printf("Unable to connect to server!\n");
WSACleanup();
return 1;
}
// ======================================================================================================
// Send and recive data :
#define DEFAULT_BUFLEN 512
int recvbuflen = DEFAULT_BUFLEN;
char *sendbuf = "this is a test";
//char recvbuf[DEFAULT_BUFLEN];
// Send an initial buffer
for(int i = 0; i<100;i++)
{
if(sendCommand(ConnectSocket,i, i, 0, i)==-1) break;
Sleep(10);
}
// Disconnecting the Client : http://msdn.microsoft.com/en-us/library/windows/desktop/bb530743(v=vs.85).aspx
// shutdown the send half of the connection since no more data will be sent
iResult = shutdown(ConnectSocket, SD_SEND);
if (iResult == SOCKET_ERROR) {
printf("shutdown failed: %d\n", WSAGetLastError());
closesocket(ConnectSocket);
WSACleanup();
return 1;
}
// cleanup
closesocket(ConnectSocket);
WSACleanup();
这对我有用
关于c++ - 写入文件,ERROR_INVALID_PARAMETER,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22882301/
我有这个代码 var myChart = new FusionCharts("../themes/clean/charts/hbullet.swf", "myChartId", "400", "75
既然写入是立即进行的(复制到内核缓冲区并返回),那么使用 io_submit 进行写入有什么好处? 事实上,它 (aio/io_submit) 看起来更糟,因为您必须在堆上分配写入缓冲区并且不能使用基
我正在使用 mootool 的 Request.JSON 从 Twitter 检索推文。收到它后,我将写入目标 div 的 .innerHTML 属性。当我在本地将其作为文件进行测试时,即 file:
最终,我想将 Vertica DB 中的数据抓取到 Spark 中,训练机器学习模型,进行预测,并将这些预测存储到另一个 Vertica DB 中。 当前的问题是确定流程最后部分的瓶颈:将 Spark
我使用 WEKA 库编写了一个 Java 程序, 训练分类算法 使用经过训练的算法对未标记的数据集运行预测 将结果写入 .csv 文件 问题在于它当前写出离散分类结果(即算法猜测一行属于哪个类别)。我
背景 - 我正在考虑使用 clickonce 通过 clickonce(通过网站)部署 WinForms 应用程序。相对简单的应用程序的要素是: - 它是一个可执行文件和一个数据库文件(sqlite)
是否有更好的解决方案来快速初始化 C 数组(在堆上创建)?就像我们使用大括号一样 double** matrix_multiply(const double **l_matrix, const dou
我正在读取 JSON 文件,取出值并进行一些更改。 基本上我向数组添加了一些值。之后我想将其写回到文件中。当我将 JSONArray 写回文件时,会被写入字符串而不是 JSONArray 对象。怎样才
我为两个应用程序使用嵌入式数据库,其中一个是服务器,另一个是客户端。客户端应用程序。可以向服务器端发送获取数据请求以检索数据并显示在表格(或其他)中。问题是这样的:如何将获取的数据保存(写入)到页面文
是否有更好的解决方案来快速初始化 C 数组(在堆上创建)?就像我们使用大括号一样 double** matrix_multiply(const double **l_matrix, const dou
从问题得出问题:找到所有 result = new ArrayList(); for (int i = 2; i >(i%8) & 0x1) == 0) { result.add(i
由于某种原因,它没有写入 CSV。谁能明白为什么它不写吗? def main(): list_of_emails = read_email_csv() #read input file, cr
关闭。 这个问题是 not reproducible or was caused by typos 。它目前不接受答案。 这个问题是由于错别字或无法再重现的问题引起的。虽然类似的问题可能在这里出现,
我目前正在开发一个保存和加载程序,但我无法获得正确的结果。 编写程序: #include #include #define FILENAME "Save" #define COUNT 6 type
import java.io.*; public class Main2 { public static void main(String[] args) throws Exception {
我需要使用预定义位置字符串“Office”从所有日历中检索所有 iOS 事件,然后将结果写入 NSLog 和 UITextView。 到目前为止,这是我的代码: #import "ViewCo
我正在尝试将 BOOL 值写入 PFInstallation 中的列,但会不停地崩溃: - (IBAction)pushSwitch:(id)sender { NSUserDefaults *push
我以前在学校学过一些简单的数据库编程,但现在我正在尝试学习最佳实践,因为我正在编写更复杂的应用程序。写入 MySQL 数据库并不难,但我想知道让分布式应用程序写入 Amazon EC2 上的远程数据库
是否可以写回到ResourceBundle?目前我正在使用 ResourceBundle 来存储信息,在运行时使用以下内容读取信息 while(ResourceBundle.getBundle("bu
关闭。这个问题是not reproducible or was caused by typos .它目前不接受答案。 这个问题是由于错别字或无法再重现的问题引起的。虽然类似的问题可能是on-topi
我是一名优秀的程序员,十分优秀!