关于C++指针问题,新手

unsigned char *pSendBuf = new unsigned char[len]
开始没给指针赋NULL,如果指针分配失败,pSendBuf是为NULL吗,还是野指针

1个回答

分配失败会抛异常。pSendBuf 指针为NULL。

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
关于C++指针问题,新手
unsigned char *pSendBuf = new unsigned char[len] 开始没给指针赋NULL,如果指针分配失败,pSendBuf是为NULL吗,还是野指针
C语言新手在指针上遇到的一个问题
![图片说明](https://img-ask.csdn.net/upload/202002/19/1582123323_582444.png) 这段代码是我在看视频时看到的 正常来讲,数组名代表数组首元素的地址,数组a[5]的首地址就是a; 然后问题就来了,第五第六行代码我理解,就是简单的输出地址,因为a代表首地址;但第六,第七行我就不明白了,&a是什么东西,a不已经是首地址了吗,&a不就是取首地址的首地址吗,这是什么意思。
C语言新手在指针(数组)方面遇到的一些问题
![图片说明](https://img-ask.csdn.net/upload/202002/15/1581765888_977519.png) 在主函数中对一个数组赋值可以这样操作:a[10]={0,0,0,0,0,0,0,0,0,0}; 但为什么在int *get(int *p,int *b, int n)函数中无法这样直接赋值(会显示初始值设置项值太多),是不是因为*b这个指针变量只能存放数组的首地址。 但如果是这个原因的话,为什么用for循环的方法却可以正常赋值,for循环方法不也是在数组中赋值吗
c语言指针问题,求大神,新手。
#include <stdio.h> #include <malloc.h> #include <Windows.h> struct Student { int age; char name[100]; float score; }; void Ininformation(int * IP_len, struct Student * IP_arr) { int i; for (i = 0; i < *IP_len; ++i) { printf("请输入%d个学生信息: \n", *IP_len); printf("请输入第%d个学生信息\n", i + 1); printf("年龄 = "); scanf_s("%d", &IP_arr[i].age); printf("分数 = "); scanf_s("%f", &IP_arr[i].score); printf("姓名 = "); scanf_s("%s", IP_arr[i].name); } } void Sortinformation(int * SP_len, struct Student * SP_arr) { int i, j; struct Student t; for (i = 0; i < *SP_len; ++i) { for (j = 0; j<j - 1 - *SP_len; ++j) { if (SP_arr[j].score > SP_arr[j + 1].score) { t = SP_arr[j]; SP_arr[j] = SP_arr[j + 1]; SP_arr[j + 1] = t; } } } } void Outinformation(int * OP_len, struct Student * OP_arr) { int i; for (i = 0; i < *OP_len; ++i) { printf("第%d个学生的信息是:\n", i + 1); printf("年龄 = %d\n", OP_arr[i].age); printf("姓名 = %s\n", OP_arr[i].name); printf("分数 = %f\n", OP_arr[i].score); printf("\n\n"); } } int main(void) { int len; struct Student * p_arr; printf("请输入总共有几个学生:\n"); printf("人数 = "); scanf_s("%d", &len); p_arr = (struct Student *)malloc(len * sizeof(struct Student)); Ininformation(&len, p_arr); Sortinformation(&len, p_arr); Outinformation(&len, p_arr); system("pause"); return 0; } 存在错误,但是编译可以通过,求大神帮看下,谢谢。![图片说明](https://img-ask.csdn.net/upload/201508/17/1439814542_621185.png)
新手请教一个c的问题,关于指针赋初始值
#include<stdio.h> int main() { char *p=NULL; scanf("%s",p); printf("%s",p); return 0; } 这段代码我在ios的终端下运行就提示Segmentation fault:11 但是不给p赋初值的话。。改称char *p;反而好使了。。为什么。。。 请教别人说是编译器的问题。能不能稍微详细的说一下为什么。。
关于c++文件操作的写入指针问题
C++文件操作中如何在不刷新内容下从头写入数据?用ios::out和app后无法用seekp(0l,ios::beg)移动写指针到开头啊,求解怎么办???
C语言关于指向一维数组的指针的用法
我是个C的新手,想请教大家,如果把指针数组定义错成int (*p)[4]后,这个东西怎么用,只能指向有四个元素的一维数组吗
C++编程新手求解:结构体与数组问题?
``` #include <iostream> using namespace std; struct bits1 //位域结构体 { unsigned char a : 1; //整数范围0~1 unsigned char b : 3; //整数范围0~7 unsigned char c : 4; //整数范围0~15 }; struct bits2 { unsigned short a : 1; //整数范围0~1 unsigned short b : 3; //整数范围0~7 unsigned short c : 4; //整数范围0~15 }; void main( ) { cout << "bits1: " << sizeof (bits1)*8 << endl; cout << "bits2: " << sizeof (bits2)*8 << endl; bits2 bit, *pbit = &bit; //定义结构体指针 bit.a = 1; bit.b = 7; bit.c = 15; cout << bit.a << " " << bit.b << " " << bit.c << endl; pbit->a = 0; pbit->b = 0; pbit->c = 0; //指针访问成员 cout << pbit->a << " " << pbit->b << " " << pbit->c << endl; system("pause"); } ``` 请对上面的程序作出以下修改: (1)写一个输出函数,输出各个data,使其不在main 中输出。函数原型为: void showNodeData( NODE *head ) ; (2)写一个逆序输出函数,以逆序输出各个NODE 的data 值。函数原型为: void reverseShowNodeData( NODE *head ) ;如果需要额外空间,请在本函数中动态分配及释放。 (3)写一个均值函数,计算各个data 的均值并返回。函数原型为:double averageNodeData( NODE *head ) ; (4)写一个查找函数,在各个data 中查找某个值KEY。函数原型为:NODE * searchNodeData( NODE *head, int KEY ) ;如果找到了,返回该NODE 地址并输出data;如果没找到,返回NULL 指针。 (5)写一个插入函数,在第K 个位置插入一个newNODE。函数原型为: bool InsertNode( NODE *head, int K, NODE *newNODE ) ;在main 函数中为newNODE 分配空间并赋值data(data 值自定)。如果插入成功返回true,并输出各个data 以证明插入成功。失败返回false。插入成功、失败的条件是什么? (6)写一个删除函数,删除第K 个位置上的NODE。函数原型为:bool DelNode( NODE *head, int K ) ; 如果删除成功,释放该NODE 内存并返回true,输出各个data 以证明删除成功。如果删除失败,给出提示信息并返回false。 (7)原题new 分配的所有NODE 内存都没有释放,编一个释放函数,原型如下:void DelList( NODE *head ) ; C++新手求各路大神解答,定感恩不尽!
C++的指针类型转换是什么意思?为什么需要类型转换?
C++的指针数据类型转换时什么意思?为什么需要类型转换?除此之外,有多少种方式进行转换,尽量详细一下,新手不太懂这个
新手有问题想请教(c语言内存和指针)
![图片说明](https://img-ask.csdn.net/upload/201704/24/1493021004_649618.png) 这几天在用memcpy的时间突然想用malloc申请一段空间然后给他挨个输入成0,1,2,3,结果就写了这么一段程序然后发现不能实现结果唉,有大神帮我解解惑吗,我是新手,正在学习阶段~~谢谢亲们
C语言新手问题scanf函数将字符串指针用%c的格式输出结果是什么?
``` #include<stdio.h> int main(){ char *string="I love China"; printf("%c\n",string); return 0; } ``` 我用vs2005执行结果是“?” 上网查了,有一篇文章“作者:Lemon_jay 来源:CSDN 原文:https://blog.csdn.net/lemon_jay/article/details/82917000 ”,这篇文章意思是这是将字符串指针的值的十进制形式输出,但%c要求输出字符,将地址值转换为对应的字符输出,网上又有讲大于127的整型用%c输出要截取低位。 我的理解是:string类型是char *,占内存是四个字节,值是16进制数,我调试string是0x004157b8,十进制是4282296,那么是直接把0x004157b8去截取低位b8,还是把string先转十进制数4282296,变成整型常量,再用int存储,而整型存储又是以补码存放(当然这个正数补码就是原码),再截低位b 8? b8十进制是184,书上ASCII码值中有从0到127,这个184怎么办,为什么输出是“?”,网上好像讲标准ASCII 码也叫基础ASCII码,使用7 位二进制数,第1位二进制为0,而这里184二进制是10111000,第一位是1。 还有,我把上面的数十进制4282296以及把它加1加2(即4282297,4282298)这样输出, ``` #include<stdio.h> int main(){ char *string="I love China"; printf("%c\n",4282296); return 0; } ``` 结果都是“?” 这样是不是把这两个整型常量先用int存储,分别是0x004157b9和0x004157ba,再截取低位,即b9和ba,十进制为185,186,还是不在127范围内,二进制为10111001,10111010,第一位还是1,这是不是说截了低位也就是只有8位二进制数后第一位是1,输出都是“?”? 网上又有讲将300,400输出,也就是如下: ``` #include<stdio.h> int main(){ char *string="I love China"; printf("%c\n",4282296); return 0; } ``` 300结果是“,”,400结果是“?”,300二进制是100101100,400二进制是110010000,这个又是不是这样:300,400都是整型常量,都被内存以0000000100101100和0000000110010000存储,再截取低位,300为00101100,400为10010000,而00101100十进制为44,%c输出就是“,”,10010000第一位是1,输出就是就是“?”? 希望各位大神能详细指教,万分感谢·
新手中的新手,huffman树关于模板和指针的问题,求教
#include<iostream> #include<queue> #include<stack> using namespace std; /*************************************************************************************************/ template<class T> class Node//结点类 { public: T Date; T* Right; T* Left; T* Parent; Node(){Date=0;Right=Left=Parent=NULL;} Node(T t){Date=t;Right=Left=Parent=NULL;} }; /*****************************************************************************************************/ template<class T> class MinHeap { private: T * Array; int CurrentSize; int MaxSize; public: MinHeap(int n); virtual ~MinHeap(){delete []Array;}; void BuildHeap(); void ShiftDown(int left);//left:开始处理的数组的下标 void ShiftUp(int pos);//从pos位置向上调整 void Print(); bool Insert(const T& node); int GetParentPos(int pos){return (pos-1)/2;}//得到父节点的位置 bool DelPink(T& node);//删除堆顶 }; template<class T> MinHeap<T>::MinHeap(int n) { MaxSize=n; Array=new Node<T>[MaxSize]; CurrentSize=0; } template<class T> void MinHeap<T>::Print() { for(int i=0;i<CurrentSize;i++) cout<<Array[i]<<" "; cout<<"\n"; } template<class T> void MinHeap<T>::ShiftDown(int left) { int i=left;//父结点 int j=2*i+1;//父结点的左孩子 T temp=Array[i];//存放父结点 while(j<CurrentSize) { if((j<CurrentSize-1)&&(Array[j].Date>Array[j+1].Date)) j++;//如果当前父结点有有孩子,比较两个孩子取大的 if(temp.Date>Array[j].Date) { Array[i]=Array[j];//父结点小于孩子,将孩子的值赋给父结点 i=j;//继续向下筛,新的父结点为当前孩子 j=j*2+1;//新的孩子为当前孩子的孩子 } else break;//父结点大于孩子 } Array[i]=temp;//交换父子结点的值 } template<class T> void MinHeap<T>::ShiftUp(int pos) { int j=pos;//当前位置 T tem=Array[j]; while((j>0)&&Array[GetParentPos(j)].Date>tem.Date)//父结点大于孩子 { cout<<Array[GetParentPos(j)].Date<<"父结点大于孩子"<<endl; Array[j]=Array[GetParentPos(j)];//将父结点的值赋给孩子 j=GetParentPos(j);//继续向上筛 } Array[j]=tem; } template<class T> void MinHeap<T>::BuildHeap() { for(int i=CurrentSize/2-1;i>=0;i--) ShiftDown(i);//从右到左依次筛 } template<class T> bool MinHeap<T>::Insert(const T & node) { if(CurrentSize==MaxSize) { cout<<"堆已满,不能插入!"<<endl; return false; } Array[CurrentSize]=node; // cout<<"插入"<<Array[CurrentSize].Date<<endl; ShiftUp(CurrentSize); // cout<<"0号"<<Array[0].Date<<endl; CurrentSize++; return true; } template<class T> bool MinHeap<T>::DelPink(T & node) { if(CurrentSize==0) { cout<<"堆已空,不能删"<<endl; return false; } node=Array[0]; Array[0]=Array[--CurrentSize]; ShiftDown(0); return true; } /************************************************************************************************** *************************霍夫曼树类***************************************************************/ template<class T> class Huffman { private: Node<T> * root; public: void MergeTree(Node<T> & ht1,Node<T> & ht2,Node<T> * parent);//将ht1和ht2合并成以parent为父结点树 Huffman(T weight[],int n); void visit(Node<T> * R); void LevelOrder(Node<T> * R); Node<T>* getroot(); }; template<class T> void Huffman<T>::MergeTree(Node<T> & ht1,Node<T> & ht2,Node<T> * parent) { parent->Left=&ht1; parent->Right=&ht2; parent->Date=ht1->Date+ht2->Date; } template<class T> Huffman<T>::Huffman(T weight[],int n) { MinHeap<Node<T> >heap(n); Node<T> *parent; Node<T> first,second; Node<T> *NodeList=new Node<T>[n]; for(int i=0;i<n;i++) { NodeList[i].Date=weight[i]; NodeList[i].Left=NodeList[i].Right=NodeList[i].Parent=NULL; heap.Insert(NodeList[i]); } for(int j=0;j<n-1;j++) { parent=new Node<T>; heap.DelPink(first); heap.DelPink(second); MergeTree(first,second,parent); heap.Insert(*parent); root=parent; } delete []NodeList; } template<class T> void Huffman<T>::visit(Node<T> * R) { cout<<R->Date<<" "; } template<class T> void Huffman<T>::LevelOrder(Node<T> * R) { queue<Node<T> *> nodequeue; Node<T> * p=R; if(p) nodequeue.push(p); while(!nodequeue.empty()) { p=nodequeue.front(); visit(p); nodequeue.pop(); if(p->Left) nodequeue.push(p->Left); if(p->Right) nodequeue.push(p->Right); } } template<class T> Node<T>* Huffman<T>::getroot() { return root; } int main() { int Weight[8]={5,29,7,8,14,23,3,11}; int n=8; Huffman<int>H(Weight,n); Node<int>* P=H.getroot(); H.LevelOrder(P); return 0; } ``` ``` 程序报错,看不懂这个错是什么意思、??有哪位大神能指点一下吗 G:\_learning\shujie\li\Ch_3_Huffiman.cpp||In member function 'void Huffman<T>::LevelOrder(Node<T>*) [with T = int]':| G:\_learning\shujie\li\Ch_3_Huffiman.cpp|207|instantiated from here| G:\_learning\shujie\li\Ch_3_Huffiman.cpp|189|error: no matching function for call to 'std::queue<Node<int>*, std::deque<Node<int>*, std::allocator<Node<int>*> > >::push(int*&)'| d:\software\codeblocks\mingw\bin\..\lib\gcc\mingw32\4.4.1\include\c++\bits\stl_queue.h|218|note: candidates are: void std::queue<_Tp, _Sequence>::push(const typename _Sequence::value_type&) [with _Tp = Node<int>*, _Sequence = std::deque<Node<int>*, std::allocator<Node<int>*> >]| G:\_learning\shujie\li\Ch_3_Huffiman.cpp|191|error: no matching function for call to 'std::queue<Node<int>*, std::deque<Node<int>*, std::allocator<Node<int>*> > >::push(int*&)'| d:\software\codeblocks\mingw\bin\..\lib\gcc\mingw32\4.4.1\include\c++\bits\stl_queue.h|218|note: candidates are: void std::queue<_Tp, _Sequence>::push(const typename _Sequence::value_type&) [with _Tp = Node<int>*, _Sequence = std::deque<Node<int>*, std::allocator<Node<int>*> >]| G:\_learning\shujie\li\Ch_3_Huffiman.cpp||In constructor 'MinHeap<T>::MinHeap(int) [with T = Node<int>]':| G:\_learning\shujie\li\Ch_3_Huffiman.cpp|150|instantiated from 'Huffman<T>::Huffman(T*, int) [with T = int]'| G:\_learning\shujie\li\Ch_3_Huffiman.cpp|205|instantiated from here| G:\_learning\shujie\li\Ch_3_Huffiman.cpp|42|error: cannot convert 'Node<Node<int> >*' to 'Node<int>*' in assignment| G:\_learning\shujie\li\Ch_3_Huffiman.cpp||In member function 'void Huffman<T>::MergeTree(Node<T>&, Node<T>&, Node<T>*) [with T = int]':| G:\_learning\shujie\li\Ch_3_Huffiman.cpp|165|instantiated from 'Huffman<T>::Huffman(T*, int) [with T = int]'| G:\_learning\shujie\li\Ch_3_Huffiman.cpp|205|instantiated from here| G:\_learning\shujie\li\Ch_3_Huffiman.cpp|143|error: cannot convert 'Node<int>*' to 'int*' in assignment| G:\_learning\shujie\li\Ch_3_Huffiman.cpp|144|error: cannot convert 'Node<int>*' to 'int*' in assignment| G:\_learning\shujie\li\Ch_3_Huffiman.cpp|145|error: base operand of '->' has non-pointer type 'Node<int>'| G:\_learning\shujie\li\Ch_3_Huffiman.cpp|145|error: base operand of '->' has non-pointer type 'Node<int>'| ||=== Build finished: 7 errors, 0 warnings ===|
一个c++指针的问题,要求编写一个函数
有这样一个题,要求编写一个函数,以char指针数组和数组中的指针数量作为参数,返回最长字符串的地址。我想请问这个函数的返回值的类型是什么呢?也就是说在声明函数时函数类型应该是 **char *** 还是其他呢?因为我认为 **char *** 指的是返回一个指向单个字符的指针而不是指向字符串的指针,而且这个函数怎么编写呢?以下是我写的源代码,虽然通过了编译,但是在运行时崩溃了 ** **char*** maxn( **char *** arr[],int len) { **char** ***max;** max=arr[0]; for(int i=1;i<len;i++) max=(strlen(max)>strlen(arr[i]))?max:arr[i]; return max; }** 还有,在请求动态分配一个指向字符串的指针数组时,应该是 **(char *) * pt = new (char *) [len]** 还是 (char) * pt = new char [len] 呢,小弟是新手,各位高手勿喷啊
新手请教关于指针函数的语法错误?
``` #include <stdio.h> int numbers[1000001] = {0}; int i,j; int m; int left, right, mid; int n, k; int BinarySearch(int (*numbers)[i], int m); int main() { // 反复读入数字和查找数字的数量 while (scanf("%d %d", &n, &k) != EOF) { // 读入给定的数字 for (i = 0; i < n; i++) { scanf("%d", &numbers[i]); } for (j = 0; j < k; j++) { // 读入待查找的数字, scanf("%d", &m); printf("%d", BinarySearch((*numbers)[i], m)); } } } int BinarySearch(int (*numbers)[i], int m) { left = 0, right = k - 1; while (left <= right) { mid = (left + right) / 2; if (numbers[mid] == m) { printf("%d", m); if (j < k) printf(" "); } if (numbers[mid] < m) { left = mid + 1; } if (numbers[mid] > m) { right = mid - 1; } printf("0"); }/*while*/ return -1; }/*function binarysearch*/ ``` Main.c:19:49: error: subscripted value is neither array nor pointer nor vector printf("%d", BinarySearch((*numbers)[i], m)); ^
小白,字符指针内存分配的问题,希望大佬帮忙解答一下
对于这样的情况: char *p="abcd"; printf("%c",p[2]); 结果就可以正常输出结果c 可是对于这样的情况: char *p; gets(p); printf("%c",p[2]); 输入字符串“abcd”,结果却无法输出结果, 这时需要用malloc函数为指针p分配内存,在定义指针下面加p=(char *)malloc(10*sizeof (char));就可以输出结果c了。 为什么第一种情况不需要分配内存,指针直接指向字符串首字母的存储地址,第二种却必须要分配内存呢? 新手,求大佬带,谢谢!
C#调用C++和opencv生成的dll库文件,其中函数中带有指针
大家好,我用C#调用C++的dll,其中一个函数中有指针,参数的定义在C++中是一个结构体,但是我现在遇到的问题是无法获取托管类型的地址和大小,或无法声明指向它的指针,下面我把这个函数在C++中的定义和我自己转到C#中的定义给大家贴出来,大家帮帮忙,本人属于C++和C#新手。 C++ 1. int THFI_Create (short nChannelNum,THFI_Param* pParam) 功能:初始化THFaceImage SDK,只需在应用程序初始化时调用一次 参数: nChannelNum,通道数,用于多线程的通道,每个线程对应一个通道. 每个线程使用的通道ID从0到nChannelNum-1,如通道数为4,那么每个线程使用的合法通道ID为0,1,2,3 pParam,算法参数 返回值: Int整型,返回实际成功初始化的通道数 struct THFI_Param { int nMinFaceSize;//min face width size can be detected,default is 50 pixels int nRollAngle;//max face roll angle,default is 30(degree) bool bOnlyDetect;//only detect face or not(if it's true,only Detect API is enable,Feature API is disable),defaule is false(Detect API is enable,and Feature API is enable) DWORD dwReserved;//reserved value,must be NULL THFI_Param() { nMinFaceSize=50; nRollAngle=30; bOnlyDetect=false; dwReserved=NULL; } }; C# [StructLayout(LayoutKind.Sequential)] public struct THFI_Param { [FieldOffset(0)] public Int16 nMinFaceSize; [FieldOffset(2)] public Int16 nRollAngle; [FieldOffset(4)] public Boolean bOnlyDetect; [FieldOffset(6)] public UInt32? dwReserved; }; [DllImport("THFaceImage.dll", EntryPoint = "THFI_Create", CharSet = CharSet.Auto)] unsafe static extern int THFI_Create(Int16 nChannelNum, THFI_Param* pParam); THFI_Create显示错误 CS0208: 无法获取托管类型(“WindowsFormsApplication1.Form1.THFI_Param”)的地址和大小,或无法声明指向它的指针。
GCC中c语言指针问题 求指导
我定义的结构体 typedef int ElemType; 4 typedef struct node { 5 ElemType data; 6 struct node *next; 7 }QueueNode,*LinkQueue; 我的一个函数 void EnterQueue(LinkQueue Q,ElemType member) 11 { 12 QueueNode *temp; 13 temp=(QueueNode *)malloc(sizeof(QueueNode)); 14 temp->data=member; 15 Q->next=temp; 16 temp->next=NULL; 17 18 } gcc 编译通过,运行core 段错误 gdb找错 显示函数里Q->next=temp; 这句话出错了,,, 新手 求指导
AsyncTask 空指针错误, 新手求教
04-08 23:15:21.478: E/BaseActivity(1456): BaseActivity.class :: onCreate() 04-08 23:15:21.488: I/LoginActivity(1456): LoginActivity.class :: onCreate() 04-08 23:15:22.248: E/HttpRequest(1456): Request Url :: http://192.168.1.101:8026/login 04-08 23:15:22.248: E/HttpRequest(1456): Parameters' HashMap :: {password=admin, username=admin} 04-08 23:15:22.538: E/HttpRequest(1456): StatusCode = 200 04-08 23:15:22.548: E/HttpRequest(1456): {"response":"login","userinfo":{"uid":0,"uname":"admin","upass":""}} 04-08 23:15:22.568: E/BaseActivity(1456): Request complete successfully 04-08 23:15:22.998: I/dalvikvm-heap(1456): Grow heap (frag case) to 23.853MB for 6554896-byte allocation 04-08 23:15:23.078: I/dalvikvm(1456): Could not find method android.content.Context.getExternalFilesDirs, referenced from method com.baidu.mapapi.utils.e.c 04-08 23:15:23.078: W/dalvikvm(1456): VFY: unable to resolve virtual method 268: Landroid/content/Context;.getExternalFilesDirs (Ljava/lang/String;)[Ljava/io/File; 04-08 23:15:23.398: I/System.out(1456): admin 04-08 23:15:23.438: I/Choreographer(1456): Skipped 31 frames! The application may be doing too much work on its main thread. 04-08 23:15:41.668: W/dalvikvm(1456): threadid=1: thread exiting with uncaught exception (group=0x4184a898) 04-08 23:15:41.668: E/AndroidRuntime(1456): FATAL EXCEPTION: main 04-08 23:15:41.668: E/AndroidRuntime(1456): java.lang.NullPointerException 04-08 23:15:41.668: E/AndroidRuntime(1456): at com.zwu.navi.BasetoActivity$AT.onPreExecute(BasetoActivity.java:439) 04-08 23:15:41.668: E/AndroidRuntime(1456): at android.os.AsyncTask.executeOnExecutor(AsyncTask.java:586) 04-08 23:15:41.668: E/AndroidRuntime(1456): at android.os.AsyncTask.execute(AsyncTask.java:534) 04-08 23:15:41.668: E/AndroidRuntime(1456): at com.zwu.navi.BasetoActivity$3.onClick(BasetoActivity.java:190) 04-08 23:15:41.668: E/AndroidRuntime(1456): at android.view.View.performClick(View.java:4476) 04-08 23:15:41.668: E/AndroidRuntime(1456): at android.view.View$PerformClick.run(View.java:18799) 04-08 23:15:41.668: E/AndroidRuntime(1456): at android.os.Handler.handleCallback(Handler.java:730) 04-08 23:15:41.668: E/AndroidRuntime(1456): at android.os.Handler.dispatchMessage(Handler.java:92) 04-08 23:15:41.668: E/AndroidRuntime(1456): at android.os.Looper.loop(Looper.java:177) 04-08 23:15:41.668: E/AndroidRuntime(1456): at android.app.ActivityThread.main(ActivityThread.java:5493) 04-08 23:15:41.668: E/AndroidRuntime(1456): at java.lang.reflect.Method.invokeNative(Native Method) 04-08 23:15:41.668: E/AndroidRuntime(1456): at java.lang.reflect.Method.invoke(Method.java:525) 04-08 23:15:41.668: E/AndroidRuntime(1456): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1225) 04-08 23:15:41.668: E/AndroidRuntime(1456): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1041) 04-08 23:15:41.668: E/AndroidRuntime(1456): at dalvik.system.NativeStart.main(Native Method) 04-08 23:16:02.548: I/Process(2064): Sending signal. PID: 2064 SIG: 9 System.out.println(getIntent().getStringExtra("test"));有数据 new AT().execute(getIntent().getStringExtra("test"));出现错误
C语言新手入门,求各位大神顺手解决(
char *get_input(); int main() { char *ceshi; ceshi=get_input(); puts(ceshi); return 0; } char*get_input() { int i=1; char str[MAX]; char*s; str[0]='$'; while((str[i]=getchar())!='='&&i<(MAX-1)) i++; if (i==(MAX-1)) puts("ERROR!!! TOO LONG!"),exit(1); str[i+1]='\0'; return str; }//是指针的问题么。。。为什么我在get_input()里加puts(str)的话就可以
C语言新手问题...老鸟莫嫌弃``
编写函数(无返回有三个参数), 向函数传递三个浮点数, 函数中实现(指针完成):1) 求得最大值和最小值(2) 交换最大值和最小值(3) 打印三个数 void MaxMinChangeEachOtherNew(float a,float b,float c){ float *max; float *min; max = &(a > b ? a : b > c ? a > b ? a : b : c); //这两行报错```为什么呢?? min = &(a < b ? a : b < c ? a < b ? a : b : c); float s = *max; *max = *min; *min = s; }
动态规划入门到熟悉,看不懂来打我啊
持续更新。。。。。。 2.1斐波那契系列问题 2.2矩阵系列问题 2.3跳跃系列问题 3.1 01背包 3.2 完全背包 3.3多重背包 3.4 一些变形选讲 2.1斐波那契系列问题 在数学上,斐波纳契数列以如下被以递归的方法定义:F(0)=0,F(1)=1, F(n)=F(n-1)+F(n-2)(n&gt;=2,n∈N*)根据定义,前十项为1, 1, 2, 3...
程序员,职场上请远离这种人!
对有些职场人来讲,甩锅就是一种生存手段。01.从大学打篮球说起上大学的时候喜欢打篮球,然后我又特别喜欢抢篮板,经常是跳起来的时候没事,落下来的时候偶尔会踩到别人的脚上,于...
终于明白阿里百度这样的大公司,为什么面试经常拿ThreadLocal考验求职者了
点击上面↑「爱开发」关注我们每晚10点,捕获技术思考和创业资源洞察什么是ThreadLocalThreadLocal是一个本地线程副本变量工具类,各个线程都拥有一份线程私...
对计算机专业来说学历真的重要吗?
我本科学校是渣渣二本,研究生学校是985,现在毕业五年,校招笔试、面试,社招面试参加了两年了,就我个人的经历来说下这个问题。 这篇文章很长,但绝对是精华,相信我,读完以后,你会知道学历不好的解决方案,记得帮我点赞哦。 先说结论,无论赞不赞同,它本质就是这样:对于技术类工作而言,学历五年以内非常重要,但有办法弥补。五年以后,不重要。 目录: 张雪峰讲述的事实 我看到的事实 为什么会这样 ...
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它是一个过程,是一个不断累积、不断沉淀、不断总结、善于传达自己的个人见解以及乐于分享的过程。
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过
Python——画一棵漂亮的樱花树(不同种樱花+玫瑰+圣诞树喔)
最近翻到一篇知乎,上面有不少用Python(大多是turtle库)绘制的树图,感觉很漂亮,我整理了一下,挑了一些我觉得不错的代码分享给大家(这些我都测试过,确实可以生成) one 樱花树 动态生成樱花 效果图(这个是动态的): 实现代码 import turtle as T import random import time # 画樱花的躯干(60,t) def Tree(branch, ...
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
一个读研让我损失了一百万的真实故事
关注我!只要10分钟,包你学会数据分析 毕业后,应该就业还是考研? 我刚出国留学那会儿,就惊讶的发现,外国local95%都不会选择读研 他们说,硕士学费很贵,时间宝贵,老板不认,所以很费 当几乎所有人都是本科学历时,硕士学历反而像个异类 在老板眼里,三年硕士远远不如3年的工作经验实用 他们甚至专门为拒绝高学历者发明了一个词,叫overoccupie...
Python 植物大战僵尸代码实现(2):植物卡片选择和种植
这篇文章要介绍的是: - 上方植物卡片栏的实现。 - 点击植物卡片,鼠标切换为植物图片。 - 鼠标移动时,判断当前在哪个方格中,并显示半透明的植物作为提示。
西游记团队中如果需要裁掉一个人,会先裁掉谁?
2019年互联网寒冬,大批企业开始裁员,下图是网上流传的一张截图: 裁员不可避免,那如何才能做到不管大环境如何变化,自身不受影响呢? 我们先来看一个有意思的故事,如果西游记取经团队需要裁员一名,会裁掉谁呢,为什么? 西游记团队组成: 1.唐僧 作为团队teamleader,有很坚韧的品性和极高的原则性,不达目的不罢休,遇到任何问题,都没有退缩过,又很得上司支持和赏识(直接得到唐太宗的任命,既给
shell脚本:备份数据库、代码上线
备份MySQL数据库 场景: 一台MySQL服务器,跑着5个数据库,在没有做主从的情况下,需要对这5个库进行备份 需求: 1)每天备份一次,需要备份所有的库 2)把备份数据存放到/data/backup/下 3)备份文件名称格式示例:dbname-2019-11-23.sql 4)需要对1天以前的所有sql文件压缩,格式为gzip 5)本地数据保留1周 6)需要把备份的数据同步到远程备份中心,假如...
聊聊C语言和指针的本质
坐着绿皮车上海到杭州,24块钱,很宽敞,在火车上非正式地聊几句。 很多编程语言都以 “没有指针” 作为自己的优势来宣传,然而,对于C语言,指针却是与生俱来的。 那么,什么是指针,为什么大家都想避开指针。 很简单, 指针就是地址,当一个地址作为一个变量存在时,它就被叫做指针,该变量的类型,自然就是指针类型。 指针的作用就是,给出一个指针,取出该指针指向地址处的值。为了理解本质,我们从计算机模型说起...
为什么你学不过动态规划?告别动态规划,谈谈我的经验
动态规划难吗?说实话,我觉得很难,特别是对于初学者来说,我当时入门动态规划的时候,是看 0-1 背包问题,当时真的是一脸懵逼。后来,我遇到动态规划的题,看的懂答案,但就是自己不会做,不知道怎么下手。就像做递归的题,看的懂答案,但下不了手,关于递归的,我之前也写过一篇套路的文章,如果对递归不大懂的,强烈建议看一看:为什么你学不会递归,告别递归,谈谈我的经验 对于动态规划,春招秋招时好多题都会用到动态...
程序员一般通过什么途径接私活?
二哥,你好,我想知道一般程序猿都如何接私活,我也想接,能告诉我一些方法吗? 上面是一个读者“烦不烦”问我的一个问题。其实不止是“烦不烦”,还有很多读者问过我类似这样的问题。 我接的私活不算多,挣到的钱也没有多少,加起来不到 20W。说实话,这个数目说出来我是有点心虚的,毕竟太少了,大家轻喷。但我想,恰好配得上“一般程序员”这个称号啊。毕竟苍蝇再小也是肉,我也算是有经验的人了。 唾弃接私活、做外...
字节跳动面试官这样问消息队列:分布式事务、重复消费、顺序消费,我整理了一下
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图、个人联系方式和人才交流群,欢迎Star和完善 前言 消息队列在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在消息队列的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸...
如何安装 IntelliJ IDEA 最新版本——详细教程
IntelliJ IDEA 简称 IDEA,被业界公认为最好的 Java 集成开发工具,尤其在智能代码助手、代码自动提示、代码重构、代码版本管理(Git、SVN、Maven)、单元测试、代码分析等方面有着亮眼的发挥。IDEA 产于捷克,开发人员以严谨著称的东欧程序员为主。IDEA 分为社区版和付费版两个版本。 我呢,一直是 Eclipse 的忠实粉丝,差不多十年的老用户了。很早就接触到了 IDEA...
面试还搞不懂redis,快看看这40道面试题(含答案和思维导图)
Redis 面试题 1、什么是 Redis?. 2、Redis 的数据类型? 3、使用 Redis 有哪些好处? 4、Redis 相比 Memcached 有哪些优势? 5、Memcache 与 Redis 的区别都有哪些? 6、Redis 是单进程单线程的? 7、一个字符串类型的值能存储最大容量是多少? 8、Redis 的持久化机制是什么?各自的优缺点? 9、Redis 常见性...
大学四年自学走来,这些珍藏的「实用工具/学习网站」我全贡献出来了
知乎高赞:文中列举了互联网一线大厂程序员都在用的工具集合,涉及面非常广,小白和老手都可以进来看看,或许有新收获。
为什么要推荐大家学习字节码?
配套视频: 为什么推荐大家学习Java字节码 https://www.bilibili.com/video/av77600176/ 一、背景 本文主要探讨:为什么要学习 JVM 字节码? 可能很多人会觉得没必要,因为平时开发用不到,而且不学这个也没耽误学习。 但是这里分享一点感悟,即人总是根据自己已经掌握的知识和技能来解决问题的。 这里有个悖论,有时候你觉得有些技术没用恰恰是...
【超详细分析】关于三次握手与四次挥手面试官想考我们什么?
在面试中,三次握手和四次挥手可以说是问的最频繁的一个知识点了,我相信大家也都看过很多关于三次握手与四次挥手的文章,今天的这篇文章,重点是围绕着面试,我们应该掌握哪些比较重要的点,哪些是比较被面试官给问到的,我觉得如果你能把我下面列举的一些点都记住、理解,我想就差不多了。 三次握手 当面试官问你为什么需要有三次握手、三次握手的作用、讲讲三次三次握手的时候,我想很多人会这样回答: 首先很多人会先讲下握...
压测学习总结(1)——高并发性能指标:QPS、TPS、RT、吞吐量详解
一、QPS,每秒查询 QPS:Queries Per Second意思是“每秒查询率”,是一台服务器每秒能够相应的查询次数,是对一个特定的查询服务器在规定时间内所处理流量多少的衡量标准。互联网中,作为域名系统服务器的机器的性能经常用每秒查询率来衡量。 二、TPS,每秒事务 TPS:是TransactionsPerSecond的缩写,也就是事务数/秒。它是软件测试结果的测量单位。一个事务是指一...
新程序员七宗罪
当我发表这篇文章《为什么每个工程师都应该开始考虑开发中的分析和编程技能呢?》时,我从未想到它会对读者产生如此积极的影响。那些想要开始探索编程和数据科学领域的人向我寻求建议;还有一些人问我下一篇文章的发布日期;还有许多人询问如何顺利过渡到这个职业。我非常鼓励大家继续分享我在这个旅程的经验,学习,成功和失败,以帮助尽可能多的人过渡到一个充满无数好处和机会的职业生涯。亲爱的读者,谢谢你。 -罗伯特。 ...
2019年Spring Boot面试都问了什么?快看看这22道面试题!
Spring Boot 面试题 1、什么是 Spring Boot? 2、Spring Boot 有哪些优点? 3、什么是 JavaConfig? 4、如何重新加载 Spring Boot 上的更改,而无需重新启动服务器? 5、Spring Boot 中的监视器是什么? 6、如何在 Spring Boot 中禁用 Actuator 端点安全性? 7、如何在自定义端口上运行 Sprin...
【图解】记一次手撕算法面试:字节跳动的面试官把我四连击了
字节跳动这家公司,应该是所有秋招的公司中,对算法最重视的一个了,每次面试基本都会让你手撕算法,今天这篇文章就记录下当时被问到的几个算法题,并且每个算法题我都详细着给出了最优解,下面再现当时的面试场景。看完一定让你有所收获 一、小牛试刀:有效括号 大部分情况下,面试官都会问一个不怎么难的问题,不过你千万别太开心,因为这道题往往可以拓展出更多有难度的问题,或者一道题看起来很简单,但是给出最优解,确实很...
面试官:关于Java性能优化,你有什么技巧
通过使用一些辅助性工具来找到程序中的瓶颈,然后就可以对瓶颈部分的代码进行优化。 一般有两种方案:即优化代码或更改设计方法。我们一般会选择后者,因为不去调用以下代码要比调用一些优化的代码更能提高程序的性能。而一个设计良好的程序能够精简代码,从而提高性能。 下面将提供一些在JAVA程序的设计和编码中,为了能够提高JAVA程序的性能,而经常采用的一些方法和技巧。 1.对象的生成和大小的调整。 J...
【图解算法面试】记一次面试:说说游戏中的敏感词过滤是如何实现的?
版权声明:本文为苦逼的码农原创。未经同意禁止任何形式转载,特别是那些复制粘贴到别的平台的,否则,必定追究。欢迎大家多多转发,谢谢。 小秋今天去面试了,面试官问了一个与敏感词过滤算法相关的问题,然而小秋对敏感词过滤算法一点也没听说过。于是,有了下下事情的发生… 面试官开怼 面试官:玩过王者荣耀吧?了解过敏感词过滤吗?,例如在游戏里,如果我们发送“你在干嘛?麻痹演员啊你?”,由于“麻痹”是一个敏感词,...
GitHub 标星 1.6w+,我发现了一个宝藏项目,作为编程新手有福了!
大家好,我是 Rocky0429,一个最近老在 GitHub 上闲逛的蒟蒻… 特别惭愧的是,虽然我很早就知道 GitHub,但是学会逛 GitHub 的时间特别晚。当时一方面是因为菜,看着这种全是英文的东西难受,不知道该怎么去玩,另一方面是一直在搞 ACM,没有做一些工程类的项目,所以想当然的以为和 GitHub 也没什么关系(当然这种想法是错误的)。 后来自己花了一个星期看完了 Pyt...
杭漂程序员2019的心路历程,还不起助学贷款,交不起房租,披荆斩棘终雨过天晴
一个杭漂2019的心酸历程,一路披荆斩棘终于还是雨过天晴。
我采访了同事,让他掏出了每天都会浏览的干货网站
前言只有光头才能变强。文本已收录至我的GitHub精选文章,欢迎Star:https://github.com/ZhongFuCheng3y/3y在周六的晚上,我日常去到公司写文章。想写...
相关热词 c# 数组类型 泛型约束 c#的赛狗日程序 c# 传递数组 可变参数 c# 生成存储过程 c# list 补集 c#获得所有窗体 c# 当前秒数转成年月日 c#中的枚举 c# 计算校验和 连续随机数不重复c#
立即提问